问题1:为什么ssh一个关闭。不再执行的程序
罪魁祸首:SIGHUP 信号让我们来看看为什么关掉形式/断开将使程序被执行死。
在Linux/Unix在。有几个概念: 进程组(process group):一个或多个进程的集合,每个进程组有唯一一个进程组ID,即进程组长进程的ID。 会话期(session):一个或多个进程组的集合,有唯一一个会话期首进程(session leader)。会话期ID为首进程的ID。 会话期能够有一个单独的控制终端(controlling terminal)。与控制终端连接的会话期首进程叫做控制进程(controlling process)。当前与终端交互的进程称为前台进程组。其余进程组称为后台进程组。依据POSIX.1定义: 挂断信号(SIGHUP)默认的动作是终止程序。
当终端接口检測到网络连接断开。将挂断信号发送给控制进程(会话期首进程)。 假设会话期首进程终止,则该信号发送到该会话期前台进程组。 一个进程退出导致一个孤儿进程组中产生时,假设随意一个孤儿进程组进程处于STOP状态,发送SIGHUP和SIGCONT信号到该进程组中全部进程。 结论:因此当网络断开或终端窗体关闭后,也就是SSH断开以后,控制进程收到SIGHUP信号退出,会导致该会话期内其它进程退出。
简而言之:就是ssh 打开以后。bash等都是他的子程序。一旦ssh关闭。系统将全部相关进程杀掉! !导致一旦ssh关闭。执行中的任务就取消了
样例:
我们来看一个样例。打开两个SSH终端窗体,在当中一个执行top命令。
在还有一个终端窗体。找到top的进程id为12912。父进程Id为12825,即登陆shell
使用pstree命令能够更清楚地看到这个关系:
使用ps-xj命令能够看到。登录shell(PID 12912)和top在同一个会话期。shell为会话期首进程。所在进程组PGID为12825,top所在进程组PGID为12912。为前台进程组。
关闭第一个SSH窗体,在还有一个窗体中能够看到top也被杀掉了。
问题2:为什么守护进程就算ssh打开的,就算关闭ssh也不会影响其执行?
由于他们的程序特殊,比方
执行这个以后。他不属於sshd这个进程组 而是单独的进程组。所以就算关闭了ssh,和他也没有不论什么关系。!结论:守护进程的启动命令本身就是特殊的,和一般命令不同的
比方mysqld_safe 这种命令 一旦使用了 就是守护进程执行 所以想把一般程序改造为守护程序是不可能的问题3 使用后台执行命令& 是否能将程序摆脱ssh?
我们做一个实验: 利用ctrl+d 注销以后 再进入系统 会不会看见这个命令再执行? 答案是 :命令被中止了!!由于他依旧属於这个ssh进程组 就算加了&也无法摆脱!
!
问题4 nohup能解决的问题
可是为了能够再注销以后 依旧能后台执行,那麼我们就能够使用nohup这个命令,我们如今開始查找find / -name ‘http’ & ,并且希望在后台能够定期执行,那麼就使用nohup:
嗯,证明执行成功。同一时候把程序执行的输出信息放到当前目录的 nohup.out 文件里去。
然后我们立即退出
再进去 打开vim nohup.out 果然信息都在那么如今我执行一个比較长的搜索:
再退出 再进去 打开vim nohup.out 发现 原来 是默认迭加再后面得 信息 看看 的确 执行了:加不加&并不会影响这个命令 仅仅是让程序 前台或者后台执行而已
能够使用tmux或者screen来保证ssh断开之后能继续执行程序。
我个人推荐使用tmux,由于screen的子界面和父界面没有不论什么不同。非常easy出错。可是tmux不一样。在子界面中执行tmux仅仅有会抛出错误信息:并且tmux还能实现分屏功能:
下面是我的.tmux.conf:
unbind C-b set -g prefix C-a setw -g mode-keys viset -g default-terminal "screen-256color" # use 256 colorsset -g display-time 5000 # status line messages displayset -g status-utf8 on # enable utf-8set -g history-limit 100000 # scrollback buffer n lines# split window like vim# vim's defination of a horizontal/vertical split is revised from tumx'sunbind %bind s split-window -hunbind '"' bind v split-window -v# move arount panes wiht hjkl, as one would in vim after C-wbind h select-pane -Lbind j select-pane -Dbind k select-pane -Ubind l select-pane -R
版权声明:本文博客原创文章。博客,未经同意,不得转载。