nodejs使用domain捕获工作进程异常

domain 可以提前捕获到异常,从而使得 process 工作进程不崩溃

var cluster = require('cluster');
var http = require('http');
var numCPUs = require('os').cpus().length;
var domain = require('domain');


if (cluster.isMaster) {
    for (var i = 0; i < numCPUs; i++) {
        // fork 出新的进程
        var worker = cluster.fork();
        console.log(worker.id);
    }
} else {
    http.createServer(function (req, res) {
        var d = domain.create();
        //  domain 捕获异常
        d.on('error', function (err) {
            res.writeHead(500);
            res.end("error\n" + err);
            d.dispose();
        });
        d.run(function () {
            // 手工出发一个异常
            throw new Error("a");
            res.writeHead(200);
            res.end("hello world\n" + process.pid);
        })
    }).listen(1234);
    // 由于domain 捕获了错误,如下代码不会执行
    process.on('uncaughtException', function (err) {
        console.log("process error")
    });
}


参考文档http://deadhorse.me/nodejs/2013/04/13/exception_and_domain.html

Node.js捕获异常的方式有多种。首先,可以使用try...catch语句块来捕获同步代码中的异常。这意味着在可能抛出异常的代码块之前使用try关键字,并在可能抛出异常的代码块之后使用catch关键字来处理异常。 另一种捕获异常的方式是通过处理异步回调函数中的异常。在Node.js中,大多数异步操作都是通过回调函数来处理的,当发生异常时,回调函数将接收到错误对象作为参数。可以在回调函数中使用try...catch语句块来捕获并处理异常。 除了使用try...catch语句块来捕获异常外,还可以使用事件和Promise来处理异常。Node.js提供了一些内置的事件,如'uncaughtException',可以用来捕获未被捕获异常。此外,使用Promise可以更灵活地处理异步操作中的异常。 下面是一个示例代码,演示了如何在Node.js中捕获异常: ```javascript const cluster = require('cluster'); const os = require('os'); const http = require('http'); const domain = require('domain'); const d = domain.create(); if (cluster.isMaster) { const cpuNum = os.cpus().length; for (let i = 0; i < cpuNum; i++) { cluster.fork(); } cluster.on('fork', worker => { console.info(`${new Date()} worker ${worker.process.pid} 进程启动成功`); }); cluster.on('exit', (worker, code, signal) => { console.info(`${new Date()} worker ${worker.process.pid} 进程启动异常退出`); cluster.fork(); }); } else { http.createServer((req, res) => { d.add(res); d.on('error', (err) => { console.log('记录的err信息', err.message); console.log('出错的 work id:', process.pid); res.end('服务器异常,请稍后再试'); cluster.worker.kill(process.pid); }); d.run(handle.bind(null, req, res)); }).listen(8080); } function handle(req, res) { if (process.pid % 2 === 0) { throw new Error(`出错了`); } res.end(`response by worker: ${process.pid}`); }; ``` 在上面的示例代码中,我们使用domain模块来捕获异常,并使用try...catch语句块来捕获同步代码中的异常。当发生异常时,我们记录了错误信息,并向客户端发送了一个错误的响应。如果是主进程发生异常,我们会重新fork一个子进程来替代。 <span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值