nohup和&后台運行,進程查看及終止
1.nohup
用途:不掛斷地運行命令。我們在使用Xshell等工具執行Linux腳本時,有時候會由於網絡問題,導致失去連接,終端斷開,程序運行一半就意外結束了。這種時候,就可以用nohup指令來運行指令,使程序可以忽略掛起信號繼續運行。
語法:nohup Command [ Arg … ] [ & ]
無論是否將 nohup 命令的輸出重定向到終端,輸出都將附加到當前目錄的 nohup.out 文件中。
如果當前目錄的 nohup.out 文件不可寫,輸出重定向到 $HOME/nohup.out 文件中。
如果沒有文件能創建或打開以用於追加,那么 Command 參數指定的命令不可調用。
2.&
用途:在后台運行
一般兩個一起用
nohup command &
3.nohup和&的區別
&:是指在后台運行,當用戶退出(掛起)的時候,命令自動跟着結束
nohup:不掛斷的運行,注意並沒有后台運行的功能,就是指用nohup運行命令可以使命令永久的執行下去,和用戶終端沒有關系,例如我們斷開SSH連接都不會影響他的運行,注意了nohup沒有后台運行的意思;&才是后台運行
因此將nohup和&結合使用,就可以實現使命令永久地在后台執行的功能
4.舉例
1 sh test.sh &
將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依然繼續運行
輸出重定向
作業在后台運行的時候,可以把輸出重定向到某個文件中,相當於一個日志文件,記錄運行過程中的輸出。使用方法:nohup command > out.file 2>&1 & command>out.file是將command的輸出重定向到out.file文件,即輸出內容不打印到屏幕上,而是輸出到out.file文件中。 在上面的例子中,0 – stdin (standard input),1 – stdout (standard output),2 – stderr (standard error) ; 2>&1是將標准錯誤(2)重定向到標准輸出(&1),標准輸出(&1)再被重定向輸入到out.file文件中。
舉個例子,我們需要保持 test.py 程序的持續運行(用於長時間訓練神經網絡),並且將控制台輸出重定向到日志文件中,那么如下命令可以輕松辦到:
nohup python test.py > log.txt &
在使用 nohup 后台運行命令之后,需要使用 exit 正常退出當前賬戶,這樣才能更好地保證命令一直在后台運行。
上述進程保持持續運行一段時間后,若想停止運行,即殺掉該進程,有如下操作:
kill -9 進程id
eg:
1
|
nohup /usr/local/node/bin/node /www/im/chat.js >> /usr/local/node/output.log 2>&1 &
|
進程號7585
查看運行的后台進程
(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}'
|
3.如果某個進程起不來,可能是某個端口被占用
查看使用某端口的進程
1
|
lsof -i:8090
|
1
|
netstat -ap|grep 8090
|
查看到進程id之后,使用netstat命令查看其占用的端口
1
|
netstat -nap|grep 7779
|
使用kill殺掉進城后再啟動
4.終止后台運行的進程
1
|
kill -9 進程號
|