如何解决Heroku 应用程序立即终止,而不是通过 SIGTERM 正常关闭
我正在尝试通过处理 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 举报,一经查实,本站将立刻删除。