linux命令後台執行

2021-07-07 03:08:45 字數 4160 閱讀 1372

有兩種方式:

1. command & :後台執行,你關掉終端會停止執行

2. nohup command & :後台執行,你關掉終端也會繼續執行

一、簡介 

& 將指令丟到後台中去執行

[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的檔案中: 

成功提交該命令之後,系統給出了它的程序號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 &

但是如上方到後台執行的程序,其父程序還是當前終端shell的程序,而一旦父程序退出,則會傳送hangup訊號給所有子程序,子程序收到hangup以後也會退出。如果我們要在退出shell的時候繼續執行程序,則需要使用nohup忽略hangup訊號,或者setsid將將父程序設為init程序(程序號為1)

$ 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

上面的試驗演示了使用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

另外還有一種方法,即使將程序在乙個subshell中執行,其實這和setsid異曲同工。方法很簡單,將命令用括號() 括起來即可:

$ (./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

注:本文試驗環境為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的效果,這在有多個命令需要在後台連續執行的時候比較方便:

$ 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

三、 nohup 

如果你正在執行乙個程序,而且你覺得在退出帳戶時該程序還不會結束,那麼可以使用nohup命令。該命令可以在你退出帳戶之後繼續執行相應的程序。nohup就是不掛起的意思( no hang up)。 該命令的一般形式為: 

nohup conmmand &

如果使用nohup命令提交作業,那麼在預設情況下該作業的所有輸出都被重定向到乙個名為nohup.out的檔案中,除非另外指定了輸出檔案:

nohup command > myout.file 2>&1 

在上面的例子中,輸出被重定向到myout.file檔案中。

四、.*,?,[...],[!...]等 

下面就是這些特殊字元: 

* 匹配檔名中的任何字串,包括空字串。 

? 匹配檔名中的任何單個字元。

[...] 匹配[ ]中所包含的任何字元。 

[!...] 匹配[ ]中非感嘆號!之後的字元。 

當s h e l l遇到上述字元時,就會把它們當作特殊字元,而不是檔名中的普通字元,這樣使用者就可以用它們來匹配相應的檔名。

1)列出以i或o開頭的檔名: 

#ls [io]*

2)列出log.開頭、後面跟隨乙個數字、然後可以是任意字串的檔名: #ls log.[0-9]* 

3)與例二相反,列出log.開頭、後面不跟隨乙個數字、然後可以是任意字串的檔名 : #ls log.[!0-9]* 

4)列出所有以lps開頭、中間可以是任何兩個字元,最後以1結尾的檔名:#ls lps??1

5)列出所有以大寫字母開頭的檔名:$ ls [a-z]* 6)列出所有以. 開頭的檔名(隱含檔案,例如. profile、.rhosts、.histo ry等): $ ls .*

jobs:檢視當前有多少在後台執行的命令

fg:將後台中的命令調至前台繼續執行。如果後台中有多個命令,可以用 fg %jobnumber將選中的命令調出,%jobnumber是通過jobs命令查到的後台正在執行的命令的序號(不是pid)

bg:將乙個在後台暫停的命令,變成繼續執行。如果後台中有多個命令,可以用bg %jobnumber將選中的命令調出,%jobnumber是通過jobs命令查到的後台正在執行的命令的序號(不是pid)

殺死程序

殺死已經啟動的程式和普通方式一樣:

pkill -9 name

killall name

kill pid

linux命令後台執行

有兩種方式 1.command 後台執行,你關掉終端會停止執行 2.nohup command 後台執行,你關掉終端也會繼續執行 1 root bin rsync.sh 用 jobs 命令檢視正在執行的任務 jobs 1 running root bin rsync.sh 如果想把它調回到前台執行,...

linux命令後台執行

有兩種方式 1.command 後台執行,你關掉終端會停止執行 2.nohup command 後台執行,你關掉終端也會繼續執行 1 root bin rsync.sh 用 jobs 命令檢視正在執行的任務 jobs 1 running root bin rsync.sh 如果想把它調回到前台執行,...

linux命令後台執行

有兩種方式 1.command 後台執行,你關掉終端會停止執行 2.nohup command 後台執行,你關掉終端也會繼續執行 1 root bin rsync.sh 用 jobs 命令檢視正在執行的任務 jobs 1 running root bin rsync.sh 如果想把它調回到前台執行,...