加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > Linux > 正文

linux – 注销时后台进程是否获得SIGHUP?

发布时间:2020-12-13 18:34:21 所属栏目:Linux 来源:网络整理
导读:这是 this question的后续行动. 我做了一些测试;看起来如果这是在物理控制台或通过SSH完成并不重要,这也不仅仅发生在SCP上;我还用cat / dev / zero测试了它.的/ dev / null的.行为完全相同: 使用在后台开始一个过程(或者在使用CTRL-Z和bg开始后将其置于后台
这是 this question的后续行动.

我做了一些测试;看起来如果这是在物理控制台或通过SSH完成并不重要,这也不仅仅发生在SCP上;我还用cat / dev / zero>测试了它.的/ dev / null的.行为完全相同:

>使用&在后台开始一个过程(或者在使用CTRL-Z和bg开始后将其置于后台);这是在不使用nohup的情况下完成的.
>注销.
>再次登录.
>这个过程仍然存在,运行愉快,现在是init的直接孩子.

如果发送SIGHUP,我可以确认SCP和CAT立即退出;我用kill -HUP测试了这个.

因此,看起来SoughUP在注销时不会被发送,至少对于后台进程(由于显而易见的原因无法使用前台进程进行测试).

这最初发生在VMware ESX 3.5的服务控制台(基于RedHat)上,但我能够在CentOS 5.4上完全复制它.

问题是,再次:在注销时,即使它们在后台运行,也不应该向进程发送SIGHUP?为什么这不会发生?

编辑

根据凯尔的回答,我用strace检查过.
正如我所期望的那样,当从发布它的shell注销时,该进程不会得到任何信号.使用服务器控制台和SSH时都会发生这种情况.

解决方法

找到答案.

对于BASH,这取决于huponexit shell选项,可以使用内置shopt命令查看和/或设置该选项.

默认情况下,此选项看起来是关闭的,至少在基于RedHat的系统上是这样.

有关BASH man page的更多信息:

The shell exits by default upon receipt of a SIGHUP. Before exiting,an interactive shell resends the SIGHUP to all jobs,running or stopped. Stopped jobs are sent SIGCONT to ensure that they receive the SIGHUP. To prevent the shell from sending the signal to a particular job,it should be removed from the jobs table with the disown builtin (see SHELL BUILTIN COMMANDS below) or marked to not receive SIGHUP using disown -h.

If the huponexit shell option has been set with shopt,bash sends a SIGHUP to all jobs when an interactive login shell exits.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读