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 秒来完成其工作?

我能想到的几个原因:

  1. 我使用的是免费测功机,但不支持功能。但是,我在文档中没有找到任何关于此的内容。如果是这样,它在哪里记录?

  2. 我需要在某处进行设置。但我没有看到任何这样的设置,也没有找到任何关于它的文档。如果是这种情况,设置是什么以及记录在哪里?

谢谢!

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...