node.js - Node.js 后台工作人员没有在 heroku 上正常关闭
问题描述
我在 Heroku(简化)上运行了以下 node.js 工作程序。Procfile
它在单个测功机上使用 a 作为工作进程运行。我期待它以退出代码优雅地关闭0
。但是,它总是以退出代码退出,1
甚至不执行完全关闭功能。
Heroku 为进程提供了 30 秒的优雅关闭时间(请参阅https://devcenter.heroku.com/articles/dynos#shutdown)。节点版本是16.13.0
.
在本地,它当然像一个魅力。
非常感谢任何帮助。
let running = true;
(async function () {
console.log('starting')
while (running) {
console.log('ping')
await new Promise(resolve => setTimeout(resolve, 1000))
}
})()
process.on('SIGTERM', function () {
console.log('received SIGTERM')
console.log('shutting down')
running = false
setTimeout(() => {
console.log('finished shutting down')
process.exit(0)
}, 1000)
})
Heroku 日志:
2021-11-11T17:27:18.884817+00:00 heroku[test-worker.1]: Restarting
2021-11-11T17:27:18.935900+00:00 heroku[test-worker.1]: State changed from up to starting
2021-11-11T17:27:18.831078+00:00 app[test-worker.1]: ping
2021-11-11T17:27:19.594077+00:00 heroku[test-worker.1]: Stopping all processes with SIGTERM
2021-11-11T17:27:19.654762+00:00 app[test-worker.1]: received SIGTERM
2021-11-11T17:27:19.654801+00:00 app[test-worker.1]: shutting down
2021-11-11T17:27:19.786370+00:00 heroku[test-worker.1]: Process exited with status 1
2021-11-11T17:27:22.660423+00:00 heroku[test-worker.1]: Starting process with command `yarn test-worker`
2021-11-11T17:27:23.532721+00:00 heroku[test-worker.1]: State changed from starting to up
2021-11-11T17:27:24.083102+00:00 app[test-worker.1]: yarn run v1.22.17
2021-11-11T17:27:24.133902+00:00 app[test-worker.1]: $ node lib/test-worker/src/index.js
2021-11-11T17:27:24.192198+00:00 app[test-worker.1]: starting
2021-11-11T17:27:24.192700+00:00 app[test-worker.1]: ping
解决方案
在 Heroku 支持的帮助下,我们能够找出原因是使用yarn
. 显然,yarn
不是等待子进程正常关闭。请参阅https://github.com/yarnpkg/yarn/issues/4667。
解决方案是不要yarn
在你的Procfile
和node
直接使用。
推荐阅读
- ansible - 更改用户并安装 ruby
- java - 空引用的安全初始化
- react-native - navigator.geolocation.getcurrentPosition() 未获取纬度和经度值
- reactjs - 如何测试 meta.valid 反应最终形式
- rest - aws mv 和 aws cp 对象之间的区别
- microsoft-graph-api - Filter 和 orderby 查询参数不适用于一个驱动图 api
- apache-spark - 如何用来自同一数据帧的其他有效条目覆盖 Spark DataFrame 中的空条目?
- c++ - 使用 boost 进程获取 shell 命令的标准输出
- php - Stripe:订阅和定期计划
- c# - 当调用对象的方法也会破坏对象时,是否建议使用 SafeHandle?