linux – 如果我启动后台进程然后注销,它会继续运行吗?

前端之家收集整理的这篇文章主要介绍了linux – 如果我启动后台进程然后注销,它会继续运行吗?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在与同事长时间讨论之后问这个问题,我真的想在这里澄清一下.

我通过添加“&”来启动后台进程到命令行或用CTRL-Z停止它并在后台用“bg”恢复它.然后我退出了.

怎么了?

我们很确定它应该被一个SIGHUP杀死,但这并没有发生;再次登录时,进程很愉快,并且pstree显示它被init“采用”了.

这是预期的行为吗?

但是,如果是的话,nohup命令的目的是什么?看起来这个过程无论如何都不会被杀死,无论是否有……

编辑1

更多细节:

>该命令是从SSH会话启动的,而不是从物理控制台启动的.
>该命令是在没有nohup和/或&amp ;;的情况下启动的然后用CTRL-Z暂停并用bg在背景中恢复.
> ssh会话没有下降.有一个实际的注销(“退出”命令).
>该过程是一个scp文件复制操作.
>再次登录时,pstree显示进程正在运行并且是init的子进程.

编辑2

更明确地陈述问题:将后台进程(使用&或bg)使其忽略SIGHUP,就像nohup命令一样?

编辑3

我尝试手动发送一个SIGHUP到scp:它退出了,所以它肯定不会忽略该信号.

然后我再次尝试启动它,将它放在后台并注销:它被init“采用”并继续运行,我在重新登录时找到了它.

我现在很困惑.看起来没有一个SIGHUP被发送到所有upong注销.

解决方法

找到答案.

对于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.

猜你在找的Linux相关文章