突发奇想 在express里面定义了一个路由:
var n = 0;
app.get('/', function(req, res){
console.log(++n);
setTimeout(function(){
console.log("ok");
res.send("ok")
},6000)
});
测试如下,打开N个浏览器标签;
打开第一个标签后访问 localhost:3000/
在6秒钟内打开第二个标签访问localhost:3000/
发现第一个请求在res.send()结束之前 第二次访问是不会有反应的;
直到第一个访问res.end 后 console.log(++n);才打印2
======================神奇的分隔符========================================
实验纠正,根据下面的评论,上面的实验是在同一个浏览器的不同标签打开的,
而用不同的浏览器,意思是指,我用谷歌浏览器打开localhost:3000/ ,然后在6秒内用ie浏览器再打开localhost:3000/,前面的请求是不会阻塞后面的,产生如下疑问。
第一个问题,假如这6秒内有一万个用户同时访问,我去....保持1万个连接吗,这个可能吗?我这懵逼了。
第二个问题,为什么同一个浏览器打开会发生阻塞呢?
天蓬老师2017-05-16 13:41:29
Node 的运行时采用的是单线程事件循环。你的代码中 setTimeout()
函数是一个阻塞操作,Node 只有一个线程执行 setTimeout()
。因此其他的操作都在 队列
中等待。
可以参考这里:http://www.nodebeginner.org/i...
phpcn_u15822017-05-16 13:41:29
这个是浏览器 有点小问题
正解如下:
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在定时器里面处理,以参数形式传递个回调,报错了,不太明白;