昨日写了一篇关于“nohup后台运行程序”文章(修复“正确操作nohup让程序始终在后台运行”中已发现的问题),今天帮助开发人员具体解决了一个问题。
注解:
Dump为研发人员开发的程序;
test.sh为测试nohup的脚本,脚本内容见20行-35行。
[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 进程名称”杀死进程。