nohup 命令运行由 Command参数和任何干系的 Arg参数指定的命令, 忽略所有挂断(SIGHUP) 旗子暗记。

在注销后利用 nohup 命令运行后台中的程序。
要运行后台中的 nohup 命令, 添加 & ( 表示“and”的符号) 到命令的尾部。

nohup 是 no hang up 的缩写, 便是不挂断的意思。

phpnohupnohup敕令和u0026应用 React

nohup命令:如果你正在运行一个进程, 而且你以为在退出帐户时该进程还不会结束, 那么可以利用nohup命令。
该命令可以在你退出帐户/关闭终端之后连续运行相应的进程。

在缺省情形下该作业的所有输出都被重定向到一个名为nohup.out的文件中。

nohup和&的差异

& : 指在后台运行

nohup : 不挂断的运行, 把稳并没有后台运行的功能, 便是指, 用nohup运行命令可以义务令永久的实行下去, 和用户终端没有关系,

例如我们断开SSH连接都不会影响他的运行, 把稳了nohup没有后台运行的意思;&才是后台运行

linux重定向:

0、1和2分别表示标准输入、标准输出和标准缺点信息输出, 可以用来指定须要重定向的标准输入或输出。

Linux下还有一个分外的文件/dev/null, 它就像一个无底洞, 所有重定向到它的信息都会消逝得无影无踪。

这一点非常有用, 当我们不须要回显程序的所有信息时, 就可以将输出重定向到/dev/null。

如果想要缺点信息都不显示, 则要标准缺点都重定向到/dev/null, 例如:

ls l>/dev/null

如果想要正常输出和缺点信息都不显示, 则要把标准输出和标准缺点都重定向到/dev/null, 例如:

# ls 1>/dev/null 2>/dev/null

还有一种做法是将缺点重定向到标准输出, 然后再重定向到 /dev/null, 例如:

# ls >/dev/null 2>&1

把稳:此处的顺序不能变动, 否则达不到想要的效果, 此时先将标准输出重定向到 /dev/null, 然后将标准缺点重定向到标准输,

由于标准输出已经重定向到了/dev/null, 因此标准缺点也会重定向到/dev/null, 于是统统悄悄静。

2>&1: 理解是将标准缺点(2)重定向到标准输出(1)

把稳: ls 1>/dev/null ">" 后面不能有空格

在利用nohup命令的时候, 常常由于输出nohup.out的路径没有写入权限, 而无法利用nohup。

nohup: ignoring input and appending output to 'nohup.out'

这是可以利用Linux重定向的方法, 将nohup.out重定向至一个有写入权限的路径, 或者直接扔到/dev/null中。

办理方法:

nohup php ws_server.php >/dev/null 2>/dev/null &

简化:

nohup php ws_server.php >/dev/null 2>&1 &

输入到日志文件中

nohup ./webcron 2>&1 > error.log &

查看运行的后台进程

> # jobs -l

[1]+ 54384 Running nohup php ws_server.php > /dev/null 2>&1 &

jobs命令只看当前终端生效的, 关闭终端后, 在另一个终端jobs已经无法看到后台跑得程序了, 此时利用ps(进程查看命令)

根据进程名查询

> # ps -ef | grep php

root 6973 1 0 17:28 ? 00:00:02 php-fpm: master process (/www/server/php/56/etc/php-fpm.conf)

www 6983 6973 0 17:28 ? 00:00:00 php-fpm: pool www

www 6984 6973 0 17:28 ? 00:00:00 php-fpm: pool www

www 6985 6973 0 17:28 ? 00:00:00 php-fpm: pool www

www 6986 6973 0 17:28 ? 00:00:00 php-fpm: pool www

www 6987 6973 0 17:28 ? 00:00:00 php-fpm: pool www

root 6999 1 0 17:28 ? 00:00:02 php-fpm: master process (/www/server/php/73/etc/php-fpm.conf)

www 7007 6999 0 17:28 ? 00:00:00 php-fpm: pool www

www 7008 6999 0 17:28 ? 00:00:00 php-fpm: pool www

www 7009 6999 0 17:28 ? 00:00:00 php-fpm: pool www

www 7010 6999 0 17:28 ? 00:00:00 php-fpm: pool www

www 7011 6999 0 17:28 ? 00:00:00 php-fpm: pool www

root 54384 8612 0 21:19 pts/0 00:00:00 php ws_server.php

root 54385 54384 0 21:19 pts/0 00:00:00 php ws_server.php

root 54388 54385 0 21:19 pts/0 00:00:00 php ws_server.php

root 54389 54385 0 21:19 pts/0 00:00:00 php ws_server.php

root 57989 8612 0 21:23 pts/0 00:00:00 grep --color=auto php

> # kill -9 54384

根据端口号查询进程ID号(PHP代码中开启websocker做事的端口号)

> # netstat -lnp | grep 9502

tcp 0 0 0.0.0.0:9502 0.0.0.0: LISTEN 54384/php

> # kill -9 54384

实例: wget命令下载文件不中断

nohup wget https://gitlab.com/humingzhe/Linux/-/archive/master/Linux-master.zip

实例: 监听 8811 端口做事是否存在(返回值1 和 0)

netstat -anp 2>/dev/null | grep 8811 | grep LISTEN | wc -l

bg 和 fg 利用

> # nohup wget https://gitlab.com/humingzhe/Linux/-/archive/master/Linux-master.zip &

查看运行的后台进程

> # jobs -l

[1]+ 24729 运行中 nohup wget https://gitlab.com/humingzhe/Linux/-/archive/master/Linux-master.zip &

后台转前台

> # fg %1

nohup wget https://gitlab.com/humingzhe/Linux/-/archive/master/Linux-master.zip

利用 Ctrl+Z 快捷键的办法, 可以将前台事情放入后台, 但是会处于停息状态, 然后规复运行

> # bg %1

[1]+ nohup wget https://gitlab.com/humingzhe/Linux/-/archive/master/Linux-master.zip &

fg 命令用于把后台事情规复到前台实行,该命令的基本格式如下:

#fg %事情号

利用 Ctrl+Z 快捷键的办法, 可以将前台事情放入后台, 但是会处于停息状态; 那么, 有没有办法可以让后台事情连续在后台实行呢? 答案是肯定的, 这就须要用到 bg 命令。

bg 命令的基本格式如下:

> # bg %事情号

以上bg、fg、Ctrl+Z 快捷键 均可以交替进行;

查看目前文件下载的大小

> # du -h Linux-master.zip

64M Linux-master.zip

动态查看文件下载的记录

> # tail -f nohup.out

48000K .......... .......... .......... .......... .......... 172M

48050K .......... .......... .......... .......... .......... 150M

48100K .......... .......... .......... .......... .......... 212M

48150K .......... .......... .......... .......... .......... 741K

把稳: 超大文件推举利用 aria2 下载工具, 见 Linux | 技巧 | 多线程下载超大文件--aria2

结论: nohup和 & 利用

利用&后台运行程序:

结果会输出到终端

利用Ctrl + C发送SIGINT旗子暗记, 程序免疫

关闭session(终端)发送SIGHUP旗子暗记, 程序关闭

利用nohup运行程序:

结果默认会输出到nohup.out

利用Ctrl + C发送SIGINT旗子暗记, 程序关闭

关闭session发送SIGHUP旗子暗记, 程序免疫

日后利用

平日线上常常利用nohup和&合营来启动程序nohup ./test &

同时免疫SIGINT和SIGHUP旗子暗记