我們來看一下什麼是阻塞操作;
我模擬一個sleep()方法來使hello star延遲10秒打印。
requestHandlers.js
代碼如下:
function start() {
console.log("Request handler 'start' was called.");
function sleep(milliSeconds) {
var startTime = new Date().getTime();
while (new Date().getTime() < startTime + milliSeconds);
}
sleep(10000);
return "Hello Start";
}
function upload() {
console.log("Request handler 'upload' was called.");
return "Hello Upload";
}
exports.start = start;
exports.upload = upload;
請求/start的時候,延遲了10秒才打印。
請求/upload的時候,並不會受影響。
接下來做一個試驗:
在第一個浏覽器窗口的地址欄中輸入 http://localhost:8888/start,但是先不要打開它!
在第二個浏覽器窗口的地址欄中輸入 http://localhost:8888/upload,同樣的,先不要打開它!
我們在第一個窗口中(“/start”)按下回車,然後快速切換到第二個窗口中(“/upload”)按下回車。
注意,發生了什麼:
/start URL 加載花了 10 秒,這和我們預期的一樣。
/upload URL 居然也花了 10 秒!
可以它在對應的請求處理程序中並沒有類似於 sleep()這樣的操作啊,這是什麼問題?
原因就是start()包含了阻塞操作。形象的說就是“它阻塞了所有其他的處理工作”。
Node.js 是單線程的,它可以在不新增額外線程的情況下對任務進行並行處理。
它通過事件輪詢(event loop)來實現並行操作,我們應該要充分利用這一點 —— 盡可能的避免阻塞操作,取而代之,多使用非阻塞操作。
下一節我們將介紹一下如何實現非阻塞操作。