nohup 详解
正文
nohup
nohup 命令运行由 Command参数和任何相关的 Arg参数指定的命令,忽略所有挂断(SIGHUP)信号。在注销后使用 nohup 命令运行后台中的程序。要运行后台中的 nohup 命令,添加 & ( 表示“and”的符号)到命令的尾部。
nohup 是 no hang up 的缩写,就是不挂断的意思。
nohup命令:如果你正在运行一个进程,而且你觉得在退出帐户时该进程还不会结束,那么可以使用nohup命令。该命令可以在你退出帐户/关闭终端之后继续运行相应的进程。
在缺省情况下该作业的所有输出都被重定向到一个名为nohup.out的文件中。
案例
1. nohup command > myout.file 2>&1 &
2. 0 22 * * * /usr/bin/python /home/pu/download_pdf/download_dfcf_pdf_to_oss.py > /home/pu/download_pdf/download_dfcf_pdf_to_oss.log 2>&1
这是放在crontab中的定时任务,晚上22点时候怕这个任务,启动这个python的脚本,并把日志写在download_dfcf_pdf_to_oss.log文件中
nohup和&的区别
& : 指在后台运行
nohup : 不挂断的运行,注意并没有后台运行的功能,,就是指,用nohup运行命令可以使命令永久的执行下去,和用户终端没有关系,例如我们断开SSH连接都不会影响他的运行,注意了nohup没有后台运行的意思;&才是后台运行
&是指在后台运行,但当用户推出(挂起)的时候,命令自动也跟着退出
nohup COMMAND &
这样就能使命令永久的在后台执行
1. sh test.sh &
将sh test.sh任务放到后台 ,即使关闭xshell退出当前session依然继续运行,但标准输出和标准错误信息会丢失(缺少的日志的输出)
将sh test.sh任务放到后台 ,关闭xshell,对应的任务也跟着停止。
2. nohup sh test.sh
将sh test.sh任务放到后台,关闭标准输入,终端不再能够接收任何输入(标准输入),重定向标准输出和标准错误到当前目录下的nohup.out文件,即使关闭xshell退出当前session依然继续运行。
3. nohup sh test.sh &
将sh test.sh任务放到后台,但是依然可以使用标准输入,终端能够接收任何输入,重定向标准输出和标准错误到当前目录下的nohup.out文件,即使关闭xshell退出当前session依然继续运行
=======测试
[root@rhel7 tmp]# pwd /tmp [root@rhel7 tmp]# ls [root@rhel7 tmp]# nohup ping 127.0.0.1 & [1] 2547 [root@rhel7 tmp]# nohup: ignoring input and appending output to ‘nohup.out’ [root@rhel7 tmp]# ls nohup.out [root@rhel7 tmp]# tail -f nohup.out --关闭当前连接,重新再打开一个ssh连接,使用tail -f nohup.out命令可以看到ping命令一直在执行 64 bytes from 127.0.0.1: icmp_seq=21 ttl=64 time=0.077 ms 64 bytes from 127.0.0.1: icmp_seq=22 ttl=64 time=0.044 ms 64 bytes from 127.0.0.1: icmp_seq=23 ttl=64 time=0.129 ms 64 bytes from 127.0.0.1: icmp_seq=24 ttl=64 time=0.084 ms 64 bytes from 127.0.0.1: icmp_seq=25 ttl=64 time=0.085 ms 64 bytes from 127.0.0.1: icmp_seq=26 ttl=64 time=0.085 ms 64 bytes from 127.0.0.1: icmp_seq=27 ttl=64 time=0.079 ms 64 bytes from 127.0.0.1: icmp_seq=28 ttl=64 time=0.078 ms 64 bytes from 127.0.0.1: icmp_seq=29 ttl=64 time=0.078 ms
指定输出到lxjtest.log。如果不指定,则输出到nohup.out文件
[root@rhel7 tmp]# nohup ping 127.0.0.1 >lxjtest.log & [1] 2641 [root@rhel7 tmp]# nohup: ignoring input and redirecting stderr to stdout [root@rhel7 tmp]# ls lxjtest.log nohup.out [root@rhel7 tmp]# tail -f lxjtest.log PING 127.0.0.1 (127.0.0.1) 56(84) bytes of data. 64 bytes from 127.0.0.1: icmp_seq=1 ttl=64 time=0.039 ms 64 bytes from 127.0.0.1: icmp_seq=2 ttl=64 time=0.073 ms 64 bytes from 127.0.0.1: icmp_seq=3 ttl=64 time=0.043 ms 64 bytes from 127.0.0.1: icmp_seq=4 ttl=64 time=0.043 ms 64 bytes from 127.0.0.1: icmp_seq=5 ttl=64 time=0.044 ms