javascript - 關于nodejs處理并發的一點小疑惑
問題描述
突發奇想 在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萬個連接嗎,這個可能嗎?我這懵逼了。第二個問題,為什么同一個瀏覽器打開會發生阻塞呢?
問題解答
回答1:Node 的運行時采用的是單線程事件循環。你的代碼中 setTimeout() 函數是一個阻塞操作,Node 只有一個線程執行 setTimeout()。因此其他的操作都在 隊列 中等待。
可以參考這里:http://www.nodebeginner.org/i...
回答2:這個是瀏覽器 有點小問題正解如下: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在定時器里面處理,以參數形式傳遞個回調,報錯了,不太明白;
回答3:不懂 Nodejs,但是一直聽說 Nodejs 能夠處理高并發,來旁聽一下。
相關文章:
1. macos - mac下docker如何設置代理2. java - 請問在main方法中寫成對象名.屬性()并賦值,與直接參參數賦值輸錯誤是什么原因?3. MySQL數據庫中文亂碼的原因4. 關docker hub上有些鏡像的tag被標記““This image has vulnerabilities””5. docker不顯示端口映射呢?6. docker - 各位電腦上有多少個容器???容器一多,自己都搞混了,咋辦呢?7. android studio總是在processes running好久8. angular.js - 關于$apply()9. docker-compose 為何找不到配置文件?10. dockerfile - 我用docker build的時候出現下邊問題 麻煩幫我看一下
