昨日写了一篇关于“nohup后台运行程序”文章(修复“正确操作nohup让程序始终在后台运行”中已发现的问题),今天帮助开发人员具体解决了一个问题。
注解:
Dump为研发人员开发的程序;
test.sh为测试nohup的脚本,脚本内容见20行-35行。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
[root@CE340 Gliver]
# killall Dump
[root@CE340 Gliver]
# ps -C test.sh
PID TTY TIME CMD
15711 pts
/0
00:00:00
test
.sh
[root@CE340 Gliver]
# killall test.sh
[1]+ Terminated
nohup
.
/test
.sh >
/dev/null
2>&1
[root@CE340 Gliver]
# nohup ./test.sh >/dev/null 2>&1 &
[1] 18531
[root@CE340 Gliver]
# ps -C test.sh
PID TTY TIME CMD
18531 pts
/0
00:00:00
test
.sh
19603 pts
/0
00:00:00
test
.sh
[root@CE340 Gliver]
# ps -C Dump
PID TTY TIME CMD
17722 pts
/0
00:00:05 Dump
[root@CE340 Gliver]
# killall Dump
[root@CE340 Gliver]
# ps -C Dump
PID TTY TIME CMD
20837 pts
/0
00:00:00 Dump
[root@CE340 Gliver]
# cat ./test.sh
#!/bin/bash
while
:
do
if
[[ ! `
ps
-ef |
grep
Dump |
grep
-
v
grep
` ]];
then
echo
"down"
#log to file
echo
"the deamon down at $(date)"
>>
/home/user/Desktop/Gliver/Dump
.log
su
-l -c
"nohup /home/user/Desktop/Gliver/Dump rtmp://172.16.172.211/livepkgr/livestream >/dev/null 2>&1 &"
# start time
if
[[ ! `
ps
-ef |
grep
Dump |
grep
-
v
grep
` ]];
then
echo
"the deamon start at $(date)"
>>
/home/user/Desktop/Gliver/Dump
.log
fi
fi
usleep 1000
done
[root@CE340 Gliver]
#
|
总结:
当执行nohup时,并不是创建一个当前进程的父进程,而是nohup能让后面紧跟的命令忽略 hangup 信号,通过忽略HUP信号来避免进程中途被中断,正如运行pstree -npu或ps -ef的第三列展示的那样。
其次nohup后面紧跟进程名,如果进程名所指向的进程接受参数,则进程名后面跟着的参数将传入进程名所指向的进程,否则将被丢弃,但重定向似乎是个例外,重定向不仅会作用于nohup本身又能作用于进程名指向的进程。
PS:一旦使用nohup,就不能使用“kill -HUP PID”,而是要使用“killall 进程名称”杀死进程。
本文转自 urey_pp 51CTO博客,原文链接:http://blog.51cto.com/dgd2010/1407161,如需转载请自行联系原作者