您好,登錄后才能下訂單哦!
怎樣進行nohup linux后臺運行輸出,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
nohup python flush.py &
這樣運行,生成了nohup.out文件,但是內容始終是空的,試了半天也不行。浪費了不少時間。
python的輸出又緩沖,導致out.log并不能夠馬上看到輸出。 -u 參數,使得python不啟用緩沖。
nohup python -u flush.py > flush.log 2>&1 &
有兩種方式:
1. command & : 后臺運行,你關掉終端會停止運行
2. nohup command & : 后臺運行,你關掉終端也會繼續運行
一、 簡介
Linux/Unix 區別于微軟平臺最大的優點就是真正的多用戶,多任務。因此在任務管理上也有別具特色的管理思想。
我們知道,在 Windows 上面,我們要么讓一個程序作為服務在后臺一直運行,要么停止這個服務。而不能讓程序在前臺后臺之間切換。而 Linux 提供了 fg 和bg命令,讓你輕松調度正在運行的任務。假設你發現前臺運行的一個程序需要很長的時間,但是需要干其他的事情,你就可以用Ctrl-Z ,掛起這個程序,然后可以看到系統提示:
[1]+ Stopped /root/bin/rsync.sh
然后我們可以把程序調度到后臺執行:(bg 后面的數字為作業號)
#bg 1
[1]+ /root/bin/rsync.sh &
用 jobs 命令查看正在運行的任務:
#jobs
[1]+ Running /root/bin/rsync.sh &
如果想把它調回到前臺運行,可以用
#fg 1
/root/bin/rsync.sh
這樣,你在控制臺上就只能等待這個任務完成了。
& 將指令丟到后臺中去執行
[ctrl]+z 將前臺任務丟到后臺中暫停
jobs 查看后臺的工作狀態
fg %jobnumber 將后臺的任務拿到前臺來處理
bg %jobnumber 將任務放到后臺中去處理
kill 管理后臺的任務
二、&
在Linux中,當在前臺運行某個作業時,終端被該作業占據;而在后臺運行作業時,它不會占據終端。可以使用&命令把作業放到后臺執行。實際上,這樣是將命令放入到一個作業隊列中了:
$ ./test.sh &
[1] 17208$ jobs -l
[1]+ 17208 Running ./test.sh &
在后臺運行作業時要當心:需要用戶交互的命令不要放在后臺執行,因為這樣你的機器就會在那里傻等。不過,作業在后臺運行一樣會將結果輸出到屏幕上,干擾你的工作。如果放在后臺運行的作業會產生大量的輸出,最好使用下面的方法把它的輸出重定向到某個文件中:
command >out.file 2>&1 &
在上面的例子中,2>&1表示所有的標準輸出和錯誤輸出都將被重定向到一個叫做out.file 的文件中。 當你成功地提交進程以后,就會顯示出一個進程號,可以用它來監控該進程,或殺死它。
例:查找名為“httpd.conf”的文件,并把所有標準輸出和錯誤輸出重定向到find.dt的文件中:
# find /etc/httpd/ -name "httpd.conf" -print >find.dt 2>&1 & [2] 7832
成功提交該命令之后,系統給出了它的進程號7832。 對于已經在前臺執行的命令,也可以重新放到后臺執行,首先按ctrl+z暫停已經運行的進程,然后使用bg命令將停止的作業放到后臺運行,例如對正在前臺執行的tesh.sh使用ctrl+z掛起它:
$ ./test.sh [1]+ Stopped ./test.sh $ bg %1 [1]+ ./test.sh & $ jobs -l [1]+ 22794 Running ./test.sh &
$ echo $$ 21734 $ nohup ./test.sh & [1] 29016 $ ps -ef | grep test 515 29710 21734 0 11:47 pts/12 00:00:00 /bin/sh ./test.sh 515 29713 21734 0 11:47 pts/12 00:00:00 grep test $ setsid ./test.sh & [1] 409 $ ps -ef | grep test 515 410 1 0 11:49 ? 00:00:00 /bin/sh ./test.sh 515 413 21734 0 11:49 pts/12 00:00:00 grep test
但是如上方到后臺執行的進程,其父進程還是當前終端shell的進程,而一旦父進程退出,則會發送hangup信號給所有子進程,子進程收到hangup以后也會退出。如果我們要在退出shell的時候繼續運行進程,則需要使用nohup忽略hangup信號,或者se
$ screen -dmS screen_test $ screen -list There is a screen on: 27963.screen_test (Detached) 1 Socket in /tmp/uscreens/S-jiangfeng. $ screen -r screen_test
tsid將將父進程設為init進程(進程號為1)
上面的試驗演示了使用nohup/setsid加上&使進程在后臺運行,同時不受當前shell退出的影響。那么對于已經在后臺運行的進程,該怎么辦呢?可以使用disown命令:
$ ./test.sh & [1] 2539 $ jobs -l [1]+ 2539 Running ./test.sh & $ disown -h %1 $ ps -ef | grep test 515 410 1 0 11:49 ? 00:00:00 /bin/sh ./test.sh 515 2542 21734 0 11:52 pts/12 00:00:00 grep test
$ (./test.sh &) $ ps -ef | grep test 515 410 1 0 11:49 ? 00:00:00 /bin/sh ./test.sh 515 12483 21734 0 11:59 pts/12 00:00:00 grep test
另外還有一種方法,即使將進程在一個subshell中執行,其實這和setsid異曲同工。方法很簡單,將命令用括號() 括起來即可:
注:本文試驗環境為Red Hat Enterprise Linux AS release 4 (Nahant Update 5),shell為/bin/bash,不同的OS和shell可能命令有些不一樣。例如AIX的ksh,沒有disown,但是可以使用nohup -p PID來獲得disown同樣的效果。
還有一種更加強大的方式是使用screen,首先創建一個斷開模式的虛擬終端,然后用-r選項重新連接這個虛擬終端,在其中執行的任何命令,都能達到nohup的效果,這在有多個命令需要在后臺連續執行的時候比較方便:
看完上述內容,你們掌握怎樣進行nohup linux后臺運行輸出的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。