天天看點

linux 背景運作指令

轉載自  http://www.cnblogs.com/lwm-1988/archive/2011/08/20/2147299.html

一、 簡介 

    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 &

但是如上方到背景執行的程序,其父程序還是目前終端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