linux命令後台運行詳解linux命令後台運行

來源:互聯網
上載者:User
linux命令後台運行

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

   有兩種方式:

   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 &

但是如上方到後台執行的進程,其父進程還是當前終端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檔案中。

四、.*,?,[...],[!...]等 
下面就是這些特殊字元: 
* 匹配檔案名稱中的任何字串,包括Null 字元串。 
? 匹配檔案名稱中的任何單個字元。 
[...] 匹配[ ]中所包含的任何字元。 
[!...] 匹配[ ]中非驚嘆號!之後的字元。 
當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

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

   有兩種方式:

   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 &

但是如上方到後台執行的進程,其父進程還是當前終端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檔案中。

四、.*,?,[...],[!...]等 
下面就是這些特殊字元: 
* 匹配檔案名稱中的任何字串,包括Null 字元串。 
? 匹配檔案名稱中的任何單個字元。 
[...] 匹配[ ]中所包含的任何字元。 
[!...] 匹配[ ]中非驚嘆號!之後的字元。 
當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
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.