Linux中咱們在shell輸入命令通常是一條一條執行,可是咱們一樣能夠用一行語句寫出多命令,下面就舉出幾個常見的方法shell
方式:command1 ; command2網絡
用;號隔開每一個命令, 每一個命令按照從左到右的順序,順序執行, 彼此之間不關心是否失敗, 全部命令都會執行。socket
例如:spa
root@Ksha:~/桌面/test# ls
1.txt 2.txt root@Ksha:~/桌面/test# ls -l 1.txt;ls -l 2.txt -rwxrw-rw- 1 root root 0 8月 3 14:37 1.txt -rwxrw-rw- 1 root root 0 8月 3 14:37 2.txt root@Ksha:~/桌面/test# ls -l 3.txt;ls -l 2.txt ls: 沒法訪問'3.txt': 沒有那個文件或目錄 -rwxrw-rw- 1 root root 0 8月 3 14:37 2.txt
首先咱們能夠看到test文件夾裏面只有兩個文件命令行
第二條命令 unix
ls -l 1.txt;ls -l 2.txt
正常執行沒問題code
第三條命令server
ls -l 3.txt;ls -l 2.txt
仍然能夠執行,即便目標文件夾沒有3.txt文件,而且報錯可是不影響該命令後半部分的執行blog
這就是分號的做用 命令從左到右順序執行,不管是否失敗,全部命令都會執行進程
上一條命令的輸出,做爲下一條命令參數
方式:command1 | command2
咱們常用這條命令來簡化一些操做下面舉例
例如咱們想查看當前的網絡狀態 使用命令netstat會發現一會兒出來好多數據,那好比咱們要查看18565端口的運行狀況呢?難道一個一個找嗎?
咱們可使用下面這個命令
root@Ksha:~/桌面/test# netstat|grep "18565" unix 3 [ ] STREAM CONNECTED 18565 /var/run/dbus/system_bus_socket
grep語句能夠正則匹配
咱們來看看這條命令 首先netstat顯示出網絡狀態 而後管道符後面的 grep "18565" 則是對於前面的netstat命令獲得的結果進行正則匹配 而後顯示結果
因此管道符用法就是上一條命令的輸出,做爲下一條命令參數
因此若是兩條命令有一個不成立 另外一個天然也不會有什麼結果
&放在啓動參數後面表示設置此進程爲後臺進程
方式:command1 &
默認狀況下,進程是前臺進程,這時就把Shell給佔據了,咱們沒法進行其餘操做,對於那些沒有交互的進程,不少時候,咱們但願將其在後臺啓動,能夠在啓動參數的時候加一個'&'實現這個目的。
shell 在執行某個命令的時候,會返回一個返回值,該返回值保存在 shell 變量 $? 中。當 $? == 0 時,表示執行成功;當 $? == 1 時(我認爲是非0的數,返回值在0-255間),表示執行失敗。
有時候,下一條命令依賴前一條命令是否執行成功。如:在成功地執行一條命令以後再執行另外一條命令,或者在一條命令執行失敗後再執行另外一條命令等。
語法格式以下:
command1 && command2 [&& command3 ...]
命令之間使用 && 鏈接,實現邏輯與的功能。
只有在 && 左邊的命令返回真(命令返回值 $? == 0),&& 右邊的命令纔會被執行。
只要有一個命令返回假(命令返回值 $? == 1),後面的命令就不會被執行。
root@Ksha:~/桌面/test# ls -l 3.txt&&ls -l 2.txt ls: 沒法訪問'3.txt': 沒有那個文件或目錄
例如此條命令 由於該文件沒有3.txt文件,因此後面的ls -l 2.txt命令也不會執行
「||」符號用法則是邏輯」或「
語法格式以下:
command1 || command2 [|| command3 ...]
命令之間使用 || 鏈接,實現邏輯或的功能。
root@Ksha:~/桌面/test# ls -l 1.txt||ls -l 2.txt -rwxrw-rw- 1 root root 0 8月 3 14:37 1.txt root@Ksha:~/桌面/test# ls -l 3.txt||ls -l 2.txt ls: 沒法訪問'3.txt': 沒有那個文件或目錄 -rwxrw-rw- 1 root root 0 8月 3 14:37 2.txt
咱們來分析下這兩條命令 第一條的前半部分已經能夠執行,因此不執行後半命令;第二條命令前半部分不可執行,因此嘗試執行後半部分的命令
從結果來看,」||"做用就是命令從左至右如有一條命令能夠執行,以後的命令就都不執行
大多數 UNIX 系統命令從你的終端接受輸入並將所產生的輸出發送回到您的終端。一個命令一般從一個叫標準輸入的地方讀取輸入,默認狀況下,這剛好是你的終端。一樣,一個命令一般將其輸出寫入到標準輸出,默認狀況下,這也是你的終端。
重定向命令列表以下:
命令 | 說明 |
---|---|
command > file | 將輸出重定向到 file。 |
command < file | 將輸入重定向到 file。 |
command >> file | 將輸出以追加的方式重定向到 file。 |
n > file | 將文件描述符爲 n 的文件重定向到 file。 |
n >> file | 將文件描述符爲 n 的文件以追加的方式重定向到 file。 |
n >& m | 將輸出文件 m 和 n 合併。 |
n <& m | 將輸入文件 m 和 n 合併。 |
<< tag | 將開始標記 tag 和結束標記 tag 之間的內容做爲輸入。 |
須要注意的是文件描述符 0 一般是標準輸入(STDIN),1 是標準輸出(STDOUT),2 是標準錯誤輸出(STDERR)。
重定向通常經過在命令間插入特定的符號來實現。特別的,這些符號的語法以下所示:
command1 > file1
上面這個命令執行command1而後將輸出的內容存入file1。
例如咱們直接執行命令 netstat -pantu
root@Ksha:~/桌面/test# netstat -pantu Active Internet connections (servers and established) Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name udp 0 0 0.0.0.0:68 0.0.0.0:* 606/dhclient
那麼咱們想讓這些結果保存在文件中怎麼辦
能夠執行
root@Ksha:~/桌面/test# netstat -pantu>3.txt
執行後,並無在終端輸出信息,這是由於輸出已被從默認的標準輸出設備(終端)重定向到指定的文件。
咱們打開3.txt看下結果
注意任何file1內的已經存在的內容將被新內容替代。若是要將新內容添加在文件末尾,請使用>>操做符。
和輸出重定向同樣,Unix 命令也能夠從文件獲取輸入,語法爲:
command1 < file1
這樣,原本須要從鍵盤獲取輸入的命令會轉移到文件讀取內容。
注意:輸出重定向是大於號(>),輸入重定向是小於號(<)。
例如咱們先在3.txt中寫上幾個文件名
而後咱們執行命令:
root@Ksha:~/桌面/test# ls -l<3.txt 總用量 4 -rwxrw-rw- 1 root root 0 8月 3 14:37 1.txt -rwxrw-rw- 1 root root 0 8月 3 14:37 2.txt -rw-r--r-- 1 root root 18 8月 4 18:15 3.txt
發現會該命令會直接讀取3.txt中咱們剛寫入的幾個文件名
咱們還能夠同時替換輸入和輸出,執行command1,從文件infile讀取內容,而後將輸出寫入到outfile中。
command1 < infile > outfile
能夠本身多嘗試練習
>&能夠起到合併輸出的效果
通常狀況下,每一個 Unix/Linux 命令運行時都會打開三個文件:
默認狀況下,command > file 將 stdout 重定向到 file,command < file 將stdin 重定向到 file。
2 表示標準錯誤文件(stderr)。
若是但願將 stdout 和 stderr 合併後重定向到 file,能夠這樣寫:
command > file 2>&1
例如 若是咱們直接執行下面這個命令(當前目錄不存在4.txt)
root@Ksha:~/桌面/test# ls -l 3.txt 4.txt>5.txt
ls: 沒法訪問'4.txt': 沒有那個文件或目錄
會發現首先命令行中提示一個錯誤 而且在5.txt中有一個輸出
那麼咱們不想錯誤文件出如今命令行而是跟結果一塊兒出如今5.txt中怎麼辦?
咱們能夠執行這個命令:
root@Ksha:~/桌面/test# ls -l 3.txt 4.txt>5.txt 2>&1
會發現此時並無報錯咱們再打開5.txt看看裏面是什麼
好的咱們已經實現了這個功能
多命令語句與重定向結合使用須要多練習纔會熟練的運用