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?
Node 的运行时采用的是单线程事件循环。你的代码中
setTimeout()
函数是一个阻塞操作,Node 只有一个线程执行setTimeout()
。因此其他的操作都在队列
中等待。可以参考这里:http://www.nodebeginner.org/i...
这个是浏览器 有点小问题
正解如下:
https://github.com/tianyk/not...
根据朴灵改变的代码:
这里注意 回调里面处理res,这样回调才能分发到不同的请求者那里;
开始写的代码;res在定时器里面处理,以参数形式传递个回调,报错了,不太明白;
不懂 Nodejs,但是一直听说 Nodejs 能够处理高并发,来旁听一下。