关于SIGTERM信号
我写了一个后台程序,在系统重启时会做一些保存工作。因此用signal()对SIGTERM进行了处理。测试时让后台程序运行,用命令kill -15 PID,保存工作运行良好。但是实际测试,我用命令 reboot,后台进程却不能接收到SIGTERM信号,未进行保存工作。
同样都是发送SIGTERM信号给进程(kill和reboot),为什么处理不一样?请指点。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(9)
>> 我用命令 reboot,后台进程却不能接收到SIGTERM信号,未进行保存工作。
不可能吧? 内核中要reboot的时候,首先会发送SIGTERM给进程,然后发送SIGKILL。
我是实际测试过的。而且不止一次,所以感觉很迷惑。
你的备份工作要做多长时间? 在发送完SIGTERM以后,shutdown可能会等待3秒左右的时间就会再发SIGKILL。
很快,不到一秒。
昨晚看UNPv1,也提到这个问题,确实是先SIGTERM再SIGKILL,要尽快handle SIGTERM,不然来不及。
找到问题的原因了。其实不是信号的问题。
如果这个程序脱离任何终端,在后台运行,那么它能接收到SIGTERM信号,并按要求执行。但是我做测试的时候,它是在一个终端上运行程序的,属于此终端的一个子进程。在reboot命令的后,终端先关闭了,此进程随即结束,并未收到SIGTERM信号。
具体没查到资料,但是可以猜测几点:reboot命令后发送的SIGTERM信号是按PID从小到大发送的;当父进程接收到SIGTERM信号后,向子进程发送SIGKILL信号立即结束。
unix经典进程关系我不太熟悉,但似乎不是父子关系的进程间会“一个被杀,子进程也被杀”, 好象是同一个session里的组长进程被杀,其他进程就被杀。
盼熟悉这块的朋友讲一下
父进程就是组长。
除非子进程显式地 setpgid
多谢大侠