且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

深入了解nohup

更新时间: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,如需转载请自行联系原作者