1,nohup
用途:不挂断地运行命令。
语法:nohup Command [ Arg … ] [ & ]
无论是否将 nohup 命令的输出重定向到终端,输出都将附加到当前目录的 nohup.out 文件中。
如果当前目录的 nohup.out 文件不可写,输出重定向到 $HOME/nohup.out 文件中。
如果没有文件能创建或打开以用于追加,那么 Command 参数指定的命令不可调用。
2,&
用途:在后台运行
一般两个一起用,不需要输入密码
nohup command &
eg:
1
|
nohup /usr/local/node/bin/node/www/im/chat.js >> /usr/local/node/output.log 2>&1 &
|
进程号7585
3,把B服务器上的文件拷贝到A服务器,要求:输入密码后,后台运行
在A服务器上输入命令:
nohup scp -P 端口号 用户名@B服务器地址:/test/cache/20180606.tar.gz .
回车后,会让你输入密码,密码输入完成回车后,点击ctrl+z,在输入如下命令即可:
# bg
至此,完成
4,查看运行的后台进程
(1)jobs -l
jobs命令只看当前终端生效的,关闭终端后,在另一个终端jobs已经无法看到后台跑得程序了,此时利用ps(进程查看命令)
(2)ps -ef
1
|
ps -aux|grep chat.js
|
a:显示所有程序 u:以用户为主的格式来显示 x:显示所有程序,不以终端机来区分
注:
用ps -def | grep查找进程很方便,最后一行总是会grep自己
用grep -v参数可以将grep命令排除掉
1
|
ps -aux|grep chat.js| grep -v grep
|
再用awk提取一下进程ID
1
|
ps -aux|grep chat.js| grep -v grep | awk
'{print $2}'
|
5,如果某个进程起不来,可能是某个端口被占用
查看使用某端口的进程
1
|
lsof -i:8090
|
1
|
netstat -ap|grep 8090
|
查看到进程id之后,使用netstat命令查看其占用的端口
1
|
netstat -nap|grep 7779
|
使用kill杀掉进城后再启动
6,终止后台运行的进程
1
|
kill -9 进程号
|