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 .*
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/11411056/viewspace-734417/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 菜鳥學Linux命令:bg fg jobs命令 任務管理Linux
- Oracle 任務管理之 ----program(程式)---scheduler(計劃)--Job(任務)Oracle
- Serverless JOB | 傳統任務新變革Server
- Serverless JOB——傳統任務新變革Server
- job任務均不執行,手工執行報job now running
- Oracle診斷案例-Job任務停止執行Oracle
- spark核心(下)——job任務提交原始碼解析Spark原始碼
- Oracle 定時任務job實際應用Oracle
- oracle建立定時任務之dbms_jobOracle
- Oracle定時任務(DBMS_Job)詳解Oracle
- micro-job分散式任務排程框架更新分散式框架
- 如何檢視資料庫中的job任務資料庫
- Oracle診斷案例:Job任務停止執行(轉)Oracle
- oracle job使用方法--實現定時任務Oracle
- Linux nohup 啟動服務且不輸出日誌Linux
- 分散式任務排程平臺XXL-JOB分散式
- Elastic-Job:動態新增任務,支援動態分片AST
- Grails整合Quartz外掛實現定時任務(Job)AIquartz
- flink學習(加餐)——job任務狀態變化
- xxl-job之實現流程任務編排思路
- Kubernetes:28---pod託管(Job:任務型pod)
- XXL-JOB定時任務框架(Oracle定製版)框架Oracle
- oracle系統包——dbms_job用法(oracle定時任務)Oracle
- 用DBMS_JOB來實現高階計劃任務
- Linux基礎命令—nohupLinux
- Linux命令nohup+screenLinux
- 【freertos】009-任務控制
- Linux | 定時任務Linux
- Linux 定時任務Linux
- Linux at 定時任務Linux
- Linux定時任務Linux
- linux 任務排程Linux
- linux的nohup命令的用法。Linux
- linux後臺執行-nohupLinux
- 【Ansible】ansible任務失敗控制
- 如何在Mac上訪問任務控制Mac
- Linux系統中延時任務及定時任務Linux
- Linux 任務計劃管理Linux