SSH是目前安全性很高的、专为远程登录会话和其他网络服务提供的协议。利用SSH协议可以有效防止远程管理过程中的信息泄漏问题。最初的SSH协议是由芬兰的一家公司开发的,但因为受版权和加密算法等等的限制,现在很多人都使用OpenSSH,就像它的名字一样,这个软件包也是开放源代码的。
在使用SSH的时候,我们可能会遇到这样的问题,假如你ssh到远端Linux/Unix服务器上运行程序,这时网络中断或者你需要关闭控制终端,那么服务器上未执行完的任务也要被关掉了,这并不是我们期望的。这个问题产生的原因和如何解决,就是本文要介绍的内容。
为什么网络中断或关闭控制终端会使正运行在服务器上的程序死掉?
在Linux/Unix中,有这样几个概念:
- 进程组(process group):一个或多个进程的集合,每一个进程组有唯一一个进程组ID,即进程组长进程的ID。
- 会话期(session):一个或多个进程组的集合,有唯一一个会话期首进程(session leader)。会话期ID为首进程的ID。
- 会话期可以有一个单独的控制终端(controlling terminal)。与控制终端连接的会话期首进程叫做控制进程(controlling process)。当前与终端交互的进程称为前台进程组。其余进程组称为后台进程组。
根据POSIX.1定义:
- 挂断信号(SIGHUP)默认的动作是终止程序。
- 当终端接口检测到网络连接断开,将挂断信号发送给控制进程(会话期首进程)。
- 如果会话期首进程终止,则该信号发送到该会话期前台进程组。
- 一个进程退出导致一个孤儿进程组中产生时,如果任意一个孤儿进程组进程处于STOP状态,发送SIGHUP和SIGCONT信号到该进程组中所有进程。
因此当网络断开或终端窗口关闭后,控制进程收到SIGHUP信号退出,会导致该会话期内其他进程退出。
如何在ssh连接断开后,通过ssh提交的程序依然运行?
解决方法有两个,一个是在你要执行的程序前加上nohup这个命令,这个命令的作用就是使程序忽略SIGHUP信号,详细介绍请看参考文章的链接;另一个是Screen窗口管理器,现在一般的linux发行版都已默认装有screen,下面简要介绍它的常用命令。
1.直接在命令行键入screen命令:Screen将创建一个执行shell的全屏窗口。你可以执行任意shell程序,就像在ssh窗口中那样。在该窗口中键入exit退出该窗口,如果这是该screen会话的唯一窗口,该screen会话退出,否则screen自动切换到前一个窗口。
2.Screen暂时中断会话操作:在screen窗口键入C-a d(Ctrl键+a键,之后按下d键),Screen会给出detached提示。
3.找回中断的screen会话:命令为screen -ls ,之后会有screen的进程号显示(假设为100)
4.重新链接中断的screen会话:screen -r 100(该会话进程号)
更多介绍就请看这篇文章吧 —> http://www.ibm.com/developerworks/cn/linux/l-cn-screen/