当我们在做服务的时候,有时候在终端界面启动了,但是往往因为网络,关闭屏幕,执行CTRL+C等原因造成ssh断开造成正在运行程序退出,使得我们的服务程序也随即终止了。其背后的主要原因在于上述的相关操作,shell默认会发送中断信号
给该终端session关联的进程,从而导致进程跟随终端退出
,为了弄清这个问题我们首先要了解两种中断信号
:
1)第一种中断信号
:sigint
:signal interrupt
,ctrl+c
会发送此信号,主动关闭程序
;
2)第二种中断信号
:sighup
: signal hang up
,关闭终端
,网络断线
,关闭屏幕
会发送此挂断信号
;
&
放在执行命令最后
,使启动的程序忽略sigint信号
,此时执行ctrl+c关闭
就不会关闭
此进程,但是当屏幕关闭
,断网
仍然会造成进程退出
。sh test.sh &
nohup
(no hang up
),意思就是不挂断运行
,用nohup
运行命令可以使命令永久执行
下去,和用户终端没有关系
,断开SSH不影响运行
,nohup
捕获了SIGHUP
,并做了忽略处理
,因此当屏幕关闭,断网等造成ssh中断时进程不会退出。但是ctrl+c可以关闭该进程
。因此大多数情况同时使用nohup和&
启动的程序,ctrl+c和关闭终端都无法关闭。在缺省情况下所有输出都被重定向到一个名为nohup.out的文件中。
nohup指令基本使用格式:
nohup Command \[ Arg ... \] \[ & \]
举例
nohup ./test.sh > out.log 2>err.log &
0 – stdin (standard input),
1 – stdout (standard output),显然 nohup command > out.log 等价于 nohup command 1> out.log,是缺省行为。
2 – stderr (standard error)
nohup ./test.sh > out.log 2>&1 &
&,nohup
怎么办呢,难道我们需要先执行ctrl + c将在前台执行的进程终止执行再重新启动吗,显然有好的方法!前台
执行的作业进程放到后台
,并且暂停
,用术语讲就是挂起
,执行后如下:[1]+ Stopped ./test.sh
查看
当前有多少在后台运行
的命令,[jobnumber
] 就是作业号。jobs
[1]+ Stopped ./test.sh
[2]+ Running ./test2.sh &
后台
中暂停(挂起)
的作业进程继续运行
。例如把1号作业(./test.sh) 放到后台运行,注意看已经带了&bg 1
[1]+ ./test.sh &
后台
中的作业进程调至前台
继续运行
,例如把2号作业(./test2.sh &)调至前台运行fg 2
./test2.sh