linux – 配置错误的systemd服务以通过SIGKILL终止

背景

我被要求为新服务foo_daemon创建一个systemd脚本,它有时会进入“坏状态”,并且不会通过SIGTERM死掉(可能是由于自定义信号处理程序).这对开发人员来说是有问题的,因为他们被指示通过以下方式启动/停止/重启服务:

> systemctl start foo_daemon.service
> systemctl stop foo_daemon.service
> systemctl restart foo_daemon.service

问题

有时候,由于foo_daemon进入了糟糕的状态,我们必须通过以下方式强行杀死它:

> systemctl kill -s KILL foo_daemon.service

如何为foo_daemon设置系统脚本,以便每当用户尝试停止/重新启动服务时,systemd将:

>尝试通过SIGTERM正常关闭foo_daemon.
>最多关闭/终止foo_daemon以完成2秒.
>如果进程仍处于活动状态,则尝试通过SIGKILL强制关闭foo_daemon(因此我们不存在PID被回收的风险,并且systemd会针对错误的PID发出SIGKILL).我们正在测试的设备迅速产生/分叉许多过程,so there is a rare but very real concern about PID recycling causing a problem.
>如果,在实践中,我只是对PID回收的偏执,我可以使用脚本只发出SIGKILL对进程的PID而不用担心杀死循环的PID.

解决方法

systemd已经支持这个开箱即用,它是 enabled by default.

您可能想要自定义的唯一事情是超时,您可以使用TimeoutStopSec =.例如:

[Service]
TimeoutStopSec=2

现在,systemd将发送一个SIGTERM,等待两秒钟让服务退出,如果没有,它将发送一个SIGKILL.

如果您的服务不支持systemd,则可能需要使用PIDFile =提供其PID文件的路径.

最后,您提到您的守护进程会产生许多进程.在这种情况下,您可能希望设置KillMode = control-group,systemd将向cgroup中的所有进程发送信号.

相关文章

文章浏览阅读1.8k次,点赞63次,收藏54次。Linux下的目录权限...
文章浏览阅读1.6k次,点赞44次,收藏38次。关于Qt的安装、Wi...
本文介绍了使用shell脚本编写一个 Hello
文章浏览阅读1.5k次,点赞37次,收藏43次。【Linux】初识Lin...
文章浏览阅读3k次,点赞34次,收藏156次。Linux超详细笔记,...
文章浏览阅读6.8k次,点赞109次,收藏114次。【Linux】 Open...