Heroku 应用程序立即终止,而不是通过 SIGTERM 正常关闭

如何解决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.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?