歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux基礎 >> 關於Linux >> Linux任務控制(bg job fg nohup &)

Linux任務控制(bg job fg nohup &)

日期:2017/3/1 16:15:08   编辑:關於Linux
Linux任務控制(bg job fg nohup &) 一、 簡介 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 .*
Copyright © Linux教程網 All Rights Reserved