javascript – Ein kleiner Zweifel an der Handhabung von Parallelität durch NodeJS
巴扎黑
巴扎黑 2017-05-16 13:39:29
0
3
682

Aus einer Laune heraus habe ich eine Expressroute definiert:

var n = 0;

app.get('/', function(req, res){
  console.log(++n);
  setTimeout(function(){
    console.log("ok");
    res.send("ok")
  },6000)

});

Der Test ist wie folgt: Öffnen Sie N Browser-Registerkarten.
Öffnen Sie die erste Registerkarte und greifen Sie auf localhost:3000/ zu.
Öffnen Sie die zweite Registerkarte innerhalb von 6 Sekunden und greifen Sie auf localhost:3000/ zu.
Es wird festgestellt, dass die erste Anforderung in res.send enthalten ist ( ) antwortet erst nach dem ersten Zugriff auf res.end
console.log(++n); = =========Magisches Trennzeichen===================================== ===

Experimentkorrektur, gemäß den Kommentaren unten wurde das obige Experiment in verschiedenen Registerkarten desselben Browsers geöffnet,aber mit unterschiedlichen Browsern, was bedeutet, dass ich Google Chrome verwendet habe, um localhost:3000 / zu öffnen und dann zu verwenden Der IE-Browser öffnet „localhost:3000/“ innerhalb von 6 Sekunden. Die vorherige Anfrage blockiert die nachfolgende nicht, was zu den folgenden Fragen führt.
Die erste Frage: Wenn 10.000 Benutzer gleichzeitig innerhalb von 6 Sekunden darauf zugreifen, sollte ich dann... 10.000 Verbindungen aufrechterhalten? Ich bin so verwirrt.
Zweite Frage: Warum wird es beim Öffnen desselben Browsers blockiert?

巴扎黑
巴扎黑

Antworte allen(3)
Peter_Zhu

Node 的运行时采用的是单线程事件循环。你的代码中 setTimeout() 函数是一个阻塞操作,Node 只有一个线程执行 setTimeout()。因此其他的操作都在 队列 中等待。

可以参考这里:http://www.nodebeginner.org/i...

phpcn_u1582

这个是浏览器 有点小问题
正解如下:
https://github.com/tianyk/not...

根据朴灵改变的代码:

var status = 'ready';


app.get('/', function(req, res){
// 进入之后监听haha事件
  proxy.once('haha', function(x){console.log(x);
      res.send("ok");
  });
  // 打印状态;
  console.log(status);
  // 判断状态,状态为ready,
  if(status == 'ready'){
    status = 'pending';
    console.log(++n);
  setTimeout(function(){
    proxy.emit('haha',"我是啊啊啊啊啊");
    console.log("ok");
    status = 'ready'
  },6000)
  }else{
    console.log("现在是pending状态,我只能等待某个请求返回触发emit")
  }

});

这里注意 回调里面处理res,这样回调才能分发到不同的请求者那里;
开始写的代码;res在定时器里面处理,以参数形式传递个回调,报错了,不太明白;

世界只因有你

不懂 Nodejs,但是一直听说 Nodejs 能够处理高并发,来旁听一下。

Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage