號和(|)在不同場景下的使用方法,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
創(chuàng)新互聯(lián)專注于坊子企業(yè)網(wǎng)站建設,響應式網(wǎng)站建設,商城系統(tǒng)網(wǎng)站開發(fā)。坊子網(wǎng)站建設公司,為坊子等地區(qū)提供建站服務。全流程按需定制設計,專業(yè)設計,全程項目跟蹤,創(chuàng)新互聯(lián)專業(yè)和態(tài)度為您提供的服務掌握連接各個命令之間的連接符號用法也是很重要的。實際上,命令的用法并不難,例如 mkdir、touch和 find 也分別可以簡單概括為“建立新目錄”、“更新文件”和“在目錄樹中查找文件”而已。
但如果要理解
mkdir test_dir 2>/dev/null || touch images.txt && find . -iname "*jpg" > backup/dir/images.txt &
這一串命令的目的,以及為什么要這樣寫,就沒有這么簡單了。
關鍵之處就在于命令之間的連接符號。掌握了這些符號的用法,不僅可以讓你更好理解整體的工作原理,還可以讓你知道如何將不同的命令有效地結(jié)合起來,提高工作效率。
我會介紹如何使用 & 號和管道符號(|)在不同場景下的使用方法。
幕后工作
我來舉一個簡單的例子,看看如何使用 & 號將下面這個命令放到后臺運行:
cp -R original/dir/ backup/dir/
這個命令的目的是將 original/dir/ 的內(nèi)容遞歸地復制到 backup/dir/ 中。雖然看起來很簡單,但是如果原目錄里面的文件太大,在執(zhí)行過程中終端就會一直被卡住。
所以,可以在命令的末尾加上一個 & 號,將這個任務放到后臺去執(zhí)行:
cp -R original/dir/ backup/dir/ &
任務被放到后臺執(zhí)行之后,就可以立即繼續(xù)在同一個終端上工作了,甚至關閉終端也不影響這個任務的正常執(zhí)行。需要注意的是,如果要求這個任務輸出內(nèi)容到標準輸出中(例如 echo 或 ls),即使使用了 &,也會等待這些輸出任務在前臺運行完畢。
當使用 & 將一個進程放置到后臺運行的時候,Bash 會提示這個進程的進程 ID。在 Linux 系統(tǒng)中運行的每一個進程都有一個唯一的進程 ID,你可以使用進程 ID 來暫停、恢復或者終止對應的進程,因此進程 ID 是非常重要的。
這個時候,只要你還停留在啟動進程的終端當中,就可以使用以下幾個命令來對管理后臺進程:
jobs 命令可以顯示當前終端正在運行的進程,包括前臺運行和后臺運行的進程。它對每個正在執(zhí)行中的進程任務分配了一個序號(這個序號不是進程 ID),可以使用這些序號來引用各個進程任務。
$ jobs[1]- Running cp -i -R original/dir/* backup/dir/ &[2]+ Running find . -iname "*jpg" > backup/dir/images.txt &
fg 命令可以將后臺運行的進程任務放到前臺運行,這樣可以比較方便地進行交互。根據(jù) jobs 命令提供的進程任務序號,再在前面加上 % 符號,就可以把相應的進程任務放到前臺運行。
$ fg %1 # 將上面序號為 1 的 cp 任務放到前臺運行 cp -i -R original/dir/* backup/dir/
如果這個進程任務是暫停狀態(tài),fg 命令會將它啟動起來。
使用 ctrl+z 組合鍵可以將前臺運行的任務暫停,僅僅是暫停,而不是將任務終止。當使用 fg 或者 bg 命令將任務重新啟動起來的時候,任務會從被暫停的位置開始執(zhí)行。但 sleep 命令是一個特例,sleep 任務被暫停的時間會計算在 sleep 時間之內(nèi)。因為 sleep 命令依據(jù)的是系統(tǒng)時鐘的時間,而不是實際運行的時間。也就是說,如果運行了 sleep 30,然后將任務暫停 30 秒以上,那么任務恢復執(zhí)行的時候會立即終止并退出。
bg 命令會將任務放置到后臺執(zhí)行,如果任務是暫停狀態(tài),也會被啟動起來。
$ bg %1 [1]+ cp -i -R original/dir/* backup/dir/ &
如上所述,以上幾個命令只能在同一個終端里才能使用。如果啟動進程任務的終端被關閉了,或者切換到了另一個終端,以上幾個命令就無法使用了。
如果要在另一個終端管理后臺進程,就需要其它工具了。例如可以使用 kill 命令從另一個終端終止某個進程:
kill -s STOP
這里的 PID 就是使用 & 將進程放到后臺時 Bash 顯示的那個進程 ID。如果你當時沒有把進程 ID 記錄下來,也可以使用 ps 命令(代表 process)來獲取所有正在運行的進程的進程 ID,就像這樣:
ps | grep cp
執(zhí)行以后會顯示出包含 cp 字符串的所有進程,例如上面例子中的 cp 進程。同時還會顯示出對應的進程 ID:
$ ps | grep cp 14444 pts/3 00:00:13 cp
在這個例子中,進程 ID 是 14444,因此可以使用以下命令來暫停這個后臺進程:
kill -s STOP 14444 注意,這里的 STOP 等同于前面提到的 ctrl+z 組合鍵的效果,也就是僅僅把進程暫停掉。
如果想要把暫停了的進程啟動起來,可以對進程發(fā)出 CONT 信號:
kill -s CONT 14444 這個給出一個可以向進程發(fā)出的常用信號列表。如果想要終止一個進程,可以發(fā)送 TERM 信號:
kill -s TERM 14444 如果進程不響應 TERM 信號并拒絕退出,還可以發(fā)送 KILL 信號強制終止進程:
kill -s KILL 14444 強制終止進程可能會有一定的風險,但如果遇到進程無節(jié)制消耗資源的情況,這樣的信號還是能夠派上用場的。
另外,如果你不確定進程 ID 是否正確,可以在 ps 命令中加上 x 參數(shù):
$ ps x| grep cp 14444 pts/3 D 0:14 cp -i -R original/dir/Hols_2014.mp4 original/dir/Hols_2015.mp4 original/dir/Hols_2016.mp4 original/dir/Hols_2017.mp4 original/dir/Hols_2018.mp4 backup/dir/
這樣就可以看到是不是你需要的進程 ID 了。
最后介紹一個將 ps 和 grep 結(jié)合到一起的命令:
$ pgrep cp 8 18 19 26 33 40 47 54 61 72 88 96 136 339 6680 13735 14444
pgrep 可以直接將帶有字符串 cp 的進程的進程 ID 顯示出來。
可以加上一些參數(shù)讓它的輸出更清晰:
$ pgrep -lx cp 14444 cp
在這里,-l 參數(shù)會讓 pgrep 將進程的名稱顯示出來,-x 參數(shù)則是讓 pgrep 完全匹配 cp 這個命令。如果還想了解這個命令的更多細節(jié),可以嘗試運行 pgrep -ax。
在命令的末尾加上 & 可以讓我們理解前臺進程和后臺進程的概念,以及如何管理這些進程。
在 UNIX/Linux 術語中,在后臺運行的進程被稱為守護進程daemon。如果你曾經(jīng)聽說過這個詞,那你現(xiàn)在應該知道它的意義了。
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注創(chuàng)新互聯(lián)-成都網(wǎng)站建設公司行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。