更新时间:2022-10-04 18:42:44
昨日写了一篇关于“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,如需转载请自行联系原作者