Ant*_*ine 8 signals amazon-web-services node.js amazon-elastic-beanstalk
我有这个在 Elastic Beanstalk 中运行的 Nodejs 应用程序。我想在应用程序退出时进行一些清理(例如部署新版本,重新启动应用程序服务器)。为此,我正在收听一些事件和信号,但似乎没有一个被触发。这是来自app.js的代码:
process.on("SIGTERM", function() {
console.log("SIGTERM, clean");
process.exit(0);
});
process.on("exit", function(code) {
console.log("Process exiting with code " + code);
});
process.on("uncaughtException", function() {
console.log("Unhandled exception occurred);
process.exit(99);
});
Run Code Online (Sandbox Code Playgroud)
当我通过管理控制台重新启动应用程序时,我在日志中看不到任何内容,即使创建了一个新节点进程并杀死了旧节点进程。
如果我手动终止进程,我可以在输出中看到日志消息。这是否意味着 Beanstalk 触发的事件不会发送终止信号?如果是这样,如何优雅地退出?
编辑:这是更多调查的结果。Beanstalk 使用 Upstart 来管理应用程序。在 /etc/init/nodejs 中,有这一行:
exec su -s /bin/sh -c 'PATH=$PATH:$NODE_HOME/bin $EB_NODE_COMMAND 2>&1' nodejs >> /var/log/nodejs/nodejs.log
Run Code Online (Sandbox Code Playgroud)
哪个运行npm start
,它使用package.json配置启动应用程序。这是我拥有的进程树:
root 29155 su -s /bin/sh -c PATH=$PATH:$NODE_HOME/bin $EB_NODE_COMMAND 2>&1 nodejs
nodejs 29156 \_ sh -c PATH=$PATH:$NODE_HOME/bin $EB_NODE_COMMAND 2>&1
nodejs 29157 \_ npm
nodejs 29168 \_ node app/app.js
Run Code Online (Sandbox Code Playgroud)
initctl status nodejs
显示第一个进程的pid。所以我猜 Upstart 向这个进程发送了一个SIGTERM,它并没有将它一直转发到我的进程。不幸的是,我仍然不知道如何解决这个问题。
归档时间: |
|
查看次数: |
1552 次 |
最近记录: |