问题描述
我正在尝试通过处理 TERM 信号让我的 Nodejs 应用程序在 Heroku 上正常关闭。我正在按照此处的示例进行操作:
https://help.heroku.com/D5GK0FHU/how-can-my-node-app-gracefully-shutdown-when-receiving-sigterm
当我在本地运行应用程序时,我看到以下输出:
Listening
tick
tick
tick
tick
然后当我终止进程时,我看到:
SIGTERM...
SIGTERM
tick
tick
tick
tick
tick
...waited 5s,exiting.
因此,应用程序收到 SIGTERM 信号,等待 5 秒然后退出。正如预期的那样。
但是,当我在 Heroku 上运行相同的应用程序并使用 heroku stop
停止它时,我在日志中看到:
2021-03-11T04:07:19.772390+00:00 app[web.1]: tick
2021-03-11T04:07:20.773763+00:00 app[web.1]: tick
2021-03-11T04:07:21.774183+00:00 app[web.1]: tick
2021-03-11T04:07:22.286757+00:00 heroku[web.1]: State changed from up to down
2021-03-11T04:07:22.775526+00:00 app[web.1]: tick
2021-03-11T04:07:23.094486+00:00 heroku[web.1]: Stopping all processes with SIGTERM
2021-03-11T04:07:23.147570+00:00 app[web.1]: SIGTERM...
2021-03-11T04:07:23.148402+00:00 app[web.1]: SIGTERM
2021-03-11T04:07:23.200434+00:00 heroku[web.1]: Process exited with status 143
所以在这里看起来我的应用程序正在接收 SIGTERM 信号并且它试图等待。然后该进程立即被 Heroku 终止。该过程似乎没有获得 30 秒的宽限超时来完成其工作。当我执行 heroku restart
或通过推送到存储库隐式重新启动 dyno 时,会发生同样的事情。
根据这篇文章,这个过程应该需要 30 秒来完成它的工作:
https://devcenter.heroku.com/articles/dynos#graceful-shutdown-with-sigterm
为什么我的流程没有得到记录的 30 秒来完成其工作?
我能想到的几个原因:
-
我需要在某处进行设置。但我没有看到任何这样的设置,也没有找到任何关于它的文档。如果是这种情况,设置是什么以及记录在哪里?
谢谢!
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)