2>&1的意思是將標准錯誤(2)也定向到標准輸出(1)的輸出文件中。
我們來具體了解下:Linux 中三種標准輸入輸出,分別是STDIN,STDOUT,STDERR,對應的數字是0,1,2。
STDIN就是標准輸入,默認從鍵盤讀取信息;STDOUT是標准輸出,默認將輸出結果輸出至終端,也就是顯示器之類的東西;STDERR是標准的錯誤信息,默認也會顯示在終端上。由於STDOUT與STDERR都會默認顯示在終端上,為了區分二者的信息,就有了編號的0,1,2的定義,用1表示STDOUT,2表示STDERR。
從command>/dev/null說起
其實這條命令是一個縮寫版,對於一個重定向命令,肯定是a > b
這種形式,那么command > /dev/null
難道是command充當a的角色,/dev/null充當b的角色。這樣看起來比較合理,其實一條命令肯定是充當不了a,肯定是command執行產生的輸出來充當a,其實就是標准輸出stdout。所以command > /dev/null
相當於執行了command 1 > /dev/null
。執行command產生了標准輸出stdout(用1表示),重定向到/dev/null的設備文件中。
說說2>&1
通過上面command > /dev/null
等價於command 1 > /dev/null
,那么對於2>&1
也就好理解了,2就是標准錯誤,1是標准輸出,那么這條命令不就是相當於把標准錯誤重定向到標准輸出么。等等是&1而不是1,這里&是什么?這里&
相當於等效於標准輸出。這里有點不好理解,先看下面。
command>a 2>a 與 command>a 2>&1的區別
通過上面的分析,對於command>a 2>&1
這條命令,等價於command 1>a 2>&1
可以理解為執行command產生的標准輸入重定向到文件a中,標准錯誤也重定向到文件a中。那么是否就說command 1>a 2>&1
等價於command 1>a 2>a
呢。其實不是,command 1>a 2>&1
與command 1>a 2>a
還是有區別的,區別就在於前者只打開一次文件a,后者會打開文件兩次,並導致stdout被stderr覆蓋。&1
的含義就可以理解為用標准輸出的引用,引用的就是重定向標准輸出產生打開的a。從IO效率上來講,command 1>a 2>&1
比command 1>a 2>a
的效率更高
再思考一下
為什么2>&1 要放在后邊呢? 我的理解是因為2(也就是錯誤輸出)要重定向到&1,也就是標准輸出的引用中,也就是標准輸出打開的文件中,所以需要現在前面打開1的輸出文件。
nohup及nohup.out
如果使用nohup執行命令,配合&的使用,則可以不掛斷的將命令執行到后台,如果沒有指定重定向文件,則輸出將附加到當前目錄的 nohup.out 文件中。如果當前目錄的 nohup.out 文件不可寫,輸出重定向到 $HOME/nohup.out 文件中,實例如下:
nohup test.pl 2>&1 &