Node.js Domain 模組
Node.js Domain(域) 簡化非同步代碼的異常處理,可以捕捉處理try catch無法捕捉的異常。引入 Domain 模組 語法格式如下:
var domain = require("domain")
domain模組,把處理多個不同的IO的操作作為一個組。註冊事件和回調到domain,當發生一個錯誤事件或拋出一個錯誤時,domain對象會被通知,不會丟失上下文環境,也不導致程式錯誤立即退出,與process.on('uncaughtException')不同。
Domain 模組可分為隱式綁定和顯式綁定:
- 隱式綁定: 把在domain上下文中定義的變數,自動綁定到domain對象
- 顯式綁定: 把不是在domain上下文中定義的變數,以代碼的方式綁定到domain對象
方法
序號 | 方法 & 描述 |
---|---|
1 | domain.run(function) 在域的上下文運行提供的函數,隱式的綁定了所有的事件分發器,計時器和底層請求。 |
2 | domain.add(emitter) 顯式的增加事件 |
3 | domain.remove(emitter) 刪除事件。 |
4 | domain.bind(callback) 返回的函數是一個對於所提供的回調函數的包裝函數。當調用這個返回的函數時,所有被拋出的錯誤都會被導向到這個域的 error 事件。 |
5 | domain.intercept(callback) 和 domain.bind(callback) 類似。除了捕捉被拋出的錯誤外,它還會攔截 Error 對象作為參數傳遞到這個函數。 |
6 | domain.enter() 進入一個非同步調用的上下文,綁定到domain。 |
7 | domain.exit() 退出當前的domain,切換到不同的鏈的非同步調用的上下文中。對應domain.enter()。 |
8 | domain.dispose() 釋放一個domain對象,讓node進程回收這部分資源。 |
9 | domain.create() 返回一個domain對象。 |
屬性
序號 | 屬性 & 描述 |
---|---|
1 | domain.members 已加入domain對象的域定時器和事件發射器的數組。 |
實例
創建 main.js 檔,代碼如下所示:
var EventEmitter = require("events").EventEmitter; var domain = require("domain"); var emitter1 = new EventEmitter(); // 創建域 var domain1 = domain.create(); domain1.on('error', function(err){ console.log("domain1 處理這個錯誤 ("+err.message+")"); }); // 顯式綁定 domain1.add(emitter1); emitter1.on('error',function(err){ console.log("監聽器處理此錯誤 ("+err.message+")"); }); emitter1.emit('error',new Error('通過監聽器來處理')); emitter1.removeAllListeners('error'); emitter1.emit('error',new Error('通過 domain1 處理')); var domain2 = domain.create(); domain2.on('error', function(err){ console.log("domain2 處理這個錯誤 ("+err.message+")"); }); // 隱式綁定 domain2.run(function(){ var emitter2 = new EventEmitter(); emitter2.emit('error',new Error('通過 domain2 處理')); }); domain1.remove(emitter1); emitter1.emit('error', new Error('轉換為異常,系統將崩潰!'));
執行以上代碼,結果如下所示:
監聽器處理此錯誤 (通過監聽器來處理) domain1 處理這個錯誤 (通過 domain1 處理) domain2 處理這個錯誤 (通過 domain2 處理) events.js:72 throw er; // Unhandled 'error' event ^ Error: 轉換為異常,系統將崩潰! at Object.<anonymous> (/www/node/main.js:40:24) at Module._compile (module.js:456:26) at Object.Module._extensions..js (module.js:474:10) at Module.load (module.js:356:32) at Function.Module._load (module.js:312:12) at Function.Module.runMain (module.js:497:10) at startup (node.js:119:16) at node.js:929:3