网易首页 > 网易号 > 正文 申请入驻

NodeJS服务总是崩溃的解决办法

0
分享至

原文链接:https://blog.csdn.net/xiunai78/article/details/40378965/

许多人都有这样一种印象,NodeJS比较快; 但是因为其是单线程,所以它不稳定,有点不安全,不适合处理复杂业务; 它比较适合对并发要求比较高,而且简单的业务场景。

事实上NodeJS里程确实有“脆弱”的一面,单线程的某处产生了“未处理的”异常确实会导致整个Node.JS的崩溃退出,来看个例子, 这里有一个node-error.js的文件:

var http = require('http');

var server = http.createServer(function (req, res) {

//这里有个错误,params 是 undefined
var ok = req.params.ok;

res.writeHead(200, {'Content-Type': 'text/plain'});
res.end('Hello World
');
});

server.listen(8080, '127.0.0.1');

console.log('Server running at http://127.0.0.1:8080/');

启动服务,并在地址栏测试一下发现 http://127.0.0.1:8080/ 不出所料,node崩溃了

$ node node-error
Server running at http://127.0.0.1:8080/

c:githubscript
ode-error.js:5
var ok = req.params.ok;
^
TypeError: Cannot read property 'ok' of undefined
at Server.
(c:githubscriptode-error.js:5:22)
at Server.EventEmitter.emit (events.js:98:17)
at HTTPParser.parser.onIncoming (http.js:2108:12)
at HTTPParser.parserOnHeadersComplete [as onHeadersComplete] (http.js:121:23)
at Socket.socket.ondata (http.js:1966:22)
at TCP.onread (net.js:525:27)

怎么解决呢?

其实Node.JS发展到今天,如果连这个问题都解决不了,那估计早就没人用了。

使用uncaughtException

我们可以uncaughtException来全局捕获未捕获的Error,同时你还可以将此函数的调用栈打印出来,捕获之后可以有效防止node进程退出,如:

process.on('uncaughtException', function (err) {
//打印出错误
console.log(err);
//打印出错误的调用栈方便调试
console.log(err.stack);
});

这相当于在node进程内部进行守护, 但这种方法很多人都是不提倡的,说明你还不能完全掌控Node.JS的异常。

使用 try/catch

我们还可以在回调前加try/catch,同样确保线程的安全。

var http = require('http');

http.createServer(function(req, res) {
try {
handler(req, res);
} catch(e) {
console.log('
', e, '
', e.stack);
try {
res.end(e.stack);
} catch(e) { }
}
}).listen(8080, '127.0.0.1');

console.log('Server running at http://127.0.0.1:8080/');

var handler = function (req, res) {
//Error Popuped
var name = req.params.name;

res.writeHead(200, {'Content-Type': 'text/plain'});
res.end('Hello ' + name);
};

这种方案的好处是,可以将错误和调用栈直接输出到当前发生的网页上。

集成到框架中

标准的HTTP响应处理会经历一系列的Middleware(HttpModule),最终到达Handler,如下图所示:

这些Middleware和Handler在NodeJS中都有一个特点,他们都是回调函数,而回调函数中是唯一会让Node在运行时崩溃的地方。根据这个 特点,我们只需要在框架中集成一处try/catch就可以相对完美地解决异常问题,而且不会影响其它用户的请求request。 事实上现在的NodeJS WEB框架几乎都是这么做的,如 OurJS开源博客所基于的 WebSvr 就有这么一处异常处理代码:

Line: 207

try {
handler(req, res);
} catch(err) {
var errorMsg
= '

+ 'Error ' + new Date().toISOString() + ' ' + req.url
+ '

+ err.stack || err.message || 'unknow error'
+ '

;

console.error(errorMsg);
Settings.showError
? res.end('')
: res.end();
}
' + errorMsg + '

那么不在回调中产生的错误怎么办?不必担心,其实这样的node程序根本就起不起来。 此外node自带的 cluster 也有一定的容错能力,它跟nginx的worker很类似,但消耗资源(内存)略大,编程也不是很方便,OurJS并没有采用此种设计。

守护NodeJS进程和记录错误日志

现 在已经基本上解决了Node.JS因异常而崩溃的问题,不过任何平台都不是100%可靠的,还有一些错误是从Node底层抛出的,有些异常 try/catch和uncaughtException都无法捕获。之前在运行ourjs的时候,会偶尔碰到底层抛出的文件流读取异常,这就是一个底层 libuv的BUG,node.js在0.10.21中进行了修复。 面对这种情况,我们就应该为nodejs应用添加守护进程,让NodeJS遭遇异常崩溃以后能马上复活。 另外,还应该把这些产生的异常记录到日志中,并让异常永远不再发生。

使用node来守护node

node-forever 提供了守护的功能和LOG日志记录功能。 安装非常容易

[sudo] npm install forever

使用也很简单

$ forever start simple-server.js
$ forever list
[0] simple-server.js [ 24597, 24596 ]

还可以看日志

forever -o out.log -e err.log my-script.js
使用shell启动脚本守护node

使用node来守护的话资源开销可能会有点大,而且也会略显复杂,OurJS直接在开机启动脚本来进行线程守护。 如在debian中放置的 ourjs 开机启动文件: /etc/init.d/ourjs 这个文件非常简单,只有启动的选项,守护的核心功能是由一个无限循环 while true; 来实现的,为了防止过于密集的错误阻塞进程,每次错误后间隔1秒重启服务

WEB_DIR='/var/www/ourjs'
WEB_APP='svr/ourjs.js'

#location of node you want to use
NODE_EXE=/root/local/bin/node

while true; do
{
$NODE_EXE $WEB_DIR/$WEB_APP config.magazine.js
echo "Stopped unexpected, restarting

"
} 2>> $WEB_DIR/error.log
sleep 1
done

错误日志记录也非常简单,直接将此进程控制台当中的错误输出到error.log文件即可: 2>> $WEB_DIR/error.log 这一行, 2 代表 Error。

特别声明:以上内容(如有图片或视频亦包括在内)为自媒体平台“网易号”用户上传并发布,本平台仅提供信息存储服务。

Notice: The content above (including the pictures and videos if any) is uploaded and posted by a user of NetEase Hao, which is a social media platform and only provides information storage services.

相关推荐
热点推荐
休渔期“第一鲜”,在青岛大批上岸:有人4小时,收获四五十斤!肥美鲜甜,今年价格低了

休渔期“第一鲜”,在青岛大批上岸:有人4小时,收获四五十斤!肥美鲜甜,今年价格低了

环球网资讯
2026-05-30 08:25:12
一盘木耳毒死7人?医生警告:木耳尽量别这样吃,比砒霜还毒

一盘木耳毒死7人?医生警告:木耳尽量别这样吃,比砒霜还毒

医学科普汇
2026-05-27 16:52:29
这和不穿有啥区别?徐璐真空上阵,身材火辣,抢了所有女星风头!

这和不穿有啥区别?徐璐真空上阵,身材火辣,抢了所有女星风头!

川渝视觉
2026-05-27 22:29:45
有没有人敢爆自己的瓜?网友:确定玩这么大吗?

有没有人敢爆自己的瓜?网友:确定玩这么大吗?

夜深爱杂谈
2026-02-18 20:55:58
10420mAh!OPPO新机官宣:5月29日,正式开售!

10420mAh!OPPO新机官宣:5月29日,正式开售!

科技堡垒
2026-05-29 11:11:33
河南网红狗被陌生男女带走以180元卖掉宰杀,主人中断环球旅行悬赏5000元寻找,民警上门时对方拒不配合,称“狗已经死了,别再折腾我们”

河南网红狗被陌生男女带走以180元卖掉宰杀,主人中断环球旅行悬赏5000元寻找,民警上门时对方拒不配合,称“狗已经死了,别再折腾我们”

极目新闻
2026-05-28 22:10:06
地毯拖拽行李费力?广州白云机场回应T3三大热点

地毯拖拽行李费力?广州白云机场回应T3三大热点

南方都市报
2026-05-30 00:19:26
上海警方:某高校在读学生沈某(男,32岁)被拘留

上海警方:某高校在读学生沈某(男,32岁)被拘留

第一财经资讯
2026-05-29 20:26:28
黄仁勋披露随特朗普访华细节:原本不去,特朗普致电坚持让其上飞机,“我就匆忙收拾了一下”

黄仁勋披露随特朗普访华细节:原本不去,特朗普致电坚持让其上飞机,“我就匆忙收拾了一下”

澎湃新闻
2026-05-29 08:24:10
1990年,作家三毛到新疆和76岁的王洛宾同居,王洛宾说:“可以同居,不可以发生关系!

1990年,作家三毛到新疆和76岁的王洛宾同居,王洛宾说:“可以同居,不可以发生关系!

犀利辣椒
2026-05-20 06:23:07
新赛季将扣近120万英镑积分!准神世界第一难保,赵心童有望登顶

新赛季将扣近120万英镑积分!准神世界第一难保,赵心童有望登顶

世界体坛观察家
2026-05-29 17:29:12
法网男单太乱了:随着德约科维奇爆大冷2-3出局,世界前十仅剩2人

法网男单太乱了:随着德约科维奇爆大冷2-3出局,世界前十仅剩2人

侧身凌空斩
2026-05-30 05:37:57
别再死盯日本,中国又一邻国背靠美国崛起,黑手已悄然伸向核力量

别再死盯日本,中国又一邻国背靠美国崛起,黑手已悄然伸向核力量

快乐彼岸
2026-05-30 05:29:53
人民日报发声!不只是给老师壮胆,更是给整个社会的未来托底

人民日报发声!不只是给老师壮胆,更是给整个社会的未来托底

教而育之
2026-05-28 09:21:33
克宫闹剧,俄副总理当面叫错普京,替身传言四起,普京反应绝了

克宫闹剧,俄副总理当面叫错普京,替身传言四起,普京反应绝了

李健政观察
2026-05-29 11:47:10
逆天发言!法拉利前主席怒喷首款纯电车:中国人都不会抄

逆天发言!法拉利前主席怒喷首款纯电车:中国人都不会抄

泡泡网
2026-05-27 11:25:19
港媒:马英九基金会风波恐酿蓝营三大悲剧

港媒:马英九基金会风波恐酿蓝营三大悲剧

金牛传声
2026-05-30 08:14:51
被五个女博士骗了

被五个女博士骗了

不正确
2026-05-28 23:01:11
辛纳比赛中离场休息18分钟,网坛名宿:这是顶级球员明显优待

辛纳比赛中离场休息18分钟,网坛名宿:这是顶级球员明显优待

懂球帝
2026-05-30 01:09:33
错过最后一班电车!濑户环奈终于演出相部屋剧情片了!

错过最后一班电车!濑户环奈终于演出相部屋剧情片了!

吃瓜党二号头目
2026-05-30 07:39:00
2026-05-30 09:40:49
Nodejs开发
Nodejs开发
分享只有程序员懂的干货
648文章数 823关注度
往期回顾 全部

科技要闻

英伟达、微软一同发布神秘预告 下周亮相?

头条要闻

参赛车手张秀军身亡:和领航员翻进水沟里被困一小时

头条要闻

参赛车手张秀军身亡:和领航员翻进水沟里被困一小时

体育要闻

即使是文班亚马,也做不到这件事

娱乐要闻

奚梦瑶何猷君将于6月在法国举行婚礼

财经要闻

双汇管不住一头猪

汽车要闻

900V+3.2秒破百 领克10+&领克10上市16.99万元起

态度原创

房产
本地
教育
公开课
军事航空

房产要闻

顺德澐璟「澐冠」再出圈:顶阶人群不是买房,是追加“传世资产”

本地新闻

用剪纸的方式,打开江苏扬州

教育要闻

从“拼盘”迈向“融合”:雄安中芬教育对话定义未来“好课堂”——2026小学跨学科融合课程建设与教学创新研讨会深度观察

公开课

李玫瑾:为什么性格比能力更重要?

军事要闻

中方公布参加香会阵容 几大议题受到关注

无障碍浏览 进入关怀版