nodejs 捕获 promise 未处理的 reject

正常情况下,对于没有捕获的 promise的reject 会直接静默的吃掉.而这不是我们想要的.
复现一下看看
function cb(){
    console.log('444');
    fdsaf.fdafdas = 777;
}

new Promise((resolve,reject)=>{
    cb(1)
})

解决:

文档

https://nodejs.org/dist/latest-v4.x/docs/api/process.html#process_event_unhandledrejection

process.on('unhandledRejection', (reason, p) => {
    console.log("Unhandled Rejection at: Promise ", p, " reason: ", reason);
    // application specific logging, throwing an error, or other logic here
});

toy code

process.on('unhandledRejection', (reason, p) => {
    console.log("Unhandled Rejection at: Promise ", p, " reason: ", reason);
    // application specific logging, throwing an error, or other logic here
});
function cb(){
    console.log('444');
    fdsaf.fdafdas = 777;
}

new Promise((resolve,reject)=>{
    cb(1)
})

toy code2 co

process.on('unhandledRejection', (reason, p) => {
    console.log("Unhandled Rejection at: Promise ", p, " reason: ", reason.stack);
    // application specific logging, throwing an error, or other logic here
});
var co = require('co');

function cb(){
    console.log('444');
    fdsaf.fdafdas = 777;
}

co(function*(){
    console.log('1111');
    throw 'myerror```';
}).then(function(value) {
    console.log(value); // Success!
}).catch(err=>{
    console.log('222');
    console.log(err); // Error!
    cb();
    console.log('!!!!');
}).catch(err=>{
    console.log('aaa :',err);
})

nodejs 6.6以后.对没有捕获的 reject 会发出一个警告.

promises: Unhandled rejections now emit a process warning after the first tick. (Benjamin Gruenbaum) #8223

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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、付费专栏及课程。

余额充值