# 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對象
## 方法
| 方法 | 描述 |
| --- | --- |
| **domain.run(function)** | 在域的上下文運行提供的函數,隱式的綁定了所有的事件分發器,計時器和底層請求。 |
| **domain.add(emitter)** | 顯式的增加事件 |
| **domain.remove(emitter)** | 刪除事件。 |
| **domain.bind(callback)** | 返回的函數是一個對于所提供的回調函數的包裝函數。當調用這個返回的函數被時,所有被拋出的錯誤都會被導向到這個域的 error 事件。 |
| **domain.intercept(callback)** | 和 domain.bind(callback) 類似。除了捕捉被拋出的錯誤外,它還會攔截 Error 對象作為參數傳遞到這個函數。 |
| **domain.enter()** | 進入一個異步調用的上下文,綁定到domain。 |
| **domain.exit()** | 退出當前的domain,切換到不同的鏈的異步調用的上下文中。對應domain.enter()。 |
| **domain.dispose()** | 釋放一個domain對象,讓node進程回收這部分資源。 |
| **domain.create()** | 返回一個domain對象。 |
## 屬性
| 屬性 | 描述 |
| --- | --- |
| **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
```
- Node.js 簡介
- Node.js 安裝配置
- Node.js 創建第一個應用
- NPM 使用介紹
- Node.js REPL(交互式解釋器)
- Node.js 回調函數
- Node.js 事件循環
- Node.js EventEmitter
- Node.js Buffer(緩沖區)
- Node.js Stream(流)
- Node.js模塊系統
- Node.js 函數
- Node.js 路由
- Node.js 全局對象
- Node.js 常用工具 util
- Node.js 文件系統
- Node.js GET/POST請求
- Node.js 工具模塊
- Node.js OS 模塊
- Node.js Path 模塊
- Node.js Net 模塊
- Node.js DNS 模塊
- Node.js Domain 模塊
- Node.js Web 模塊
- Node.js Express 框架
- Node.js RESTful API
- Node.js 多進程
- Node.js JXcore 打包
- 免責聲明