DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> 輕松創建nodejs服務器(7):阻塞操作的實現
輕松創建nodejs服務器(7):阻塞操作的實現
編輯:關於JavaScript     

我們來看一下什麼是阻塞操作;

我模擬一個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)來實現並行操作,我們應該要充分利用這一點 —— 盡可能的避免阻塞操作,取而代之,多使用非阻塞操作。

下一節我們將介紹一下如何實現非阻塞操作。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved