javascript - 關(guān)于nodejs處理并發(fā)的一點小疑惑
問題描述
突發(fā)奇想 在express里面定義了一個路由:
var n = 0;app.get(’/’, function(req, res){ console.log(++n); setTimeout(function(){ console.log('ok'); res.send('ok') },6000)});
測試如下,打開N個瀏覽器標(biāo)簽;打開第一個標(biāo)簽后訪問 localhost:3000/ 在6秒鐘內(nèi)打開第二個標(biāo)簽訪問localhost:3000/發(fā)現(xiàn)第一個請求在res.send()結(jié)束之前 第二次訪問是不會有反應(yīng)的;直到第一個訪問res.end 后 console.log(++n);才打印2======================神奇的分隔符========================================實驗糾正,根據(jù)下面的評論,上面的實驗是在同一個瀏覽器的不同標(biāo)簽打開的,而用不同的瀏覽器,意思是指,我用谷歌瀏覽器打開localhost:3000/ ,然后在6秒內(nèi)用ie瀏覽器再打開localhost:3000/,前面的請求是不會阻塞后面的,產(chǎn)生如下疑問。第一個問題,假如這6秒內(nèi)有一萬個用戶同時訪問,我去....保持1萬個連接嗎,這個可能嗎?我這懵逼了。第二個問題,為什么同一個瀏覽器打開會發(fā)生阻塞呢?
問題解答
回答1:Node 的運行時采用的是單線程事件循環(huán)。你的代碼中 setTimeout() 函數(shù)是一個阻塞操作,Node 只有一個線程執(zhí)行 setTimeout()。因此其他的操作都在 隊列 中等待。
可以參考這里:http://www.nodebeginner.org/i...
回答2:這個是瀏覽器 有點小問題正解如下:https://github.com/tianyk/not...
根據(jù)樸靈改變的代碼:
var status = ’ready’;app.get(’/’, function(req, res){// 進入之后監(jiān)聽haha事件 proxy.once(’haha’, function(x){console.log(x); res.send('ok'); }); // 打印狀態(tài); console.log(status); // 判斷狀態(tài),狀態(tài)為ready, if(status == ’ready’){ status = ’pending’; console.log(++n); setTimeout(function(){ proxy.emit(’haha’,'我是啊啊啊啊啊'); console.log('ok'); status = ’ready’ },6000) }else{ console.log('現(xiàn)在是pending狀態(tài),我只能等待某個請求返回觸發(fā)emit') }});
這里注意 回調(diào)里面處理res,這樣回調(diào)才能分發(fā)到不同的請求者那里;開始寫的代碼;res在定時器里面處理,以參數(shù)形式傳遞個回調(diào),報錯了,不太明白;
回答3:不懂 Nodejs,但是一直聽說 Nodejs 能夠處理高并發(fā),來旁聽一下。
相關(guān)文章:
1. html - 微信瀏覽器h5<video>標(biāo)簽問題2. python - 如何對列表中的列表進行頻率統(tǒng)計?3. node.js - 為什么微信的消息MsgId出現(xiàn)重復(fù)了,無法排重了。。4. java - mysql緩存問題5. javascript - 關(guān)于Node 、 commonJs、 vue 之間的故事6. android - 像支付寶到位這種點擊marker點擊變大怎么做的7. javascript - 關(guān)于ios微信端瀏覽器網(wǎng)頁的一些問題8. python - 如何正則字符串中的所有漢字9. android 微信是如何實現(xiàn)即時更新好友頭像的10. 黑客 - Python模塊安全權(quán)限
