1. command & : 後臺運行,你關掉終端會中止運行
2. nohup command & : 後臺運行,你關掉終端也會繼續運行bash
1、 簡介
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
這樣,你在控制檯上就只能等待這個任務完成了。app
& 將指令丟到後臺中去執行
[ctrl]+z 將前臺任務丟到後臺中暫停
jobs 查看後臺的工做狀態
fg %jobnumber 將後臺的任務拿到前臺來處理
bg %jobnumber 將任務放到後臺中去處理
kill 管理後臺的任務spa
2、&htm
在Linux中,當在前臺運行某個做業時,終端被該做業佔據;而在後臺運行做業時,它不會佔據終端。可使用&命令把做業放到後臺執行。實際上,這樣是將命令放入到一個做業隊列中了:blog
$ ./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
3、 nohup
若是你正在運行一個進程,並且你以爲在退出賬戶時該進程還不會結束,那麼可使用nohup命令。該命令能夠在你退出賬戶以後繼續運行相應的進程。nohup就是不掛起的意思( no hang up)。 該命令的通常形式爲:
nohup conmmand &
若是使用nohup命令提交做業,那麼在缺省狀況下該做業的全部輸出都被重定向到一個名爲nohup.out的文件中,除非另外指定了輸出文件:
nohup command > myout.file 2>&1
在上面的例子中,輸出被重定向到myout.file文件中。
4、.*,?,[...],[!...]等
下面就是這些特殊字符:
* 匹配文件名中的任何字符串,包括空字符串。
? 匹配文件名中的任何單個字符。
[...] 匹配[ ]中所包含的任何字符。
[!...] 匹配[ ]中非感嘆號!以後的字符。
當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 .*