原文:https://blog.csdn.net/ggxiaobai/article/details/53507530
我們在Linux下經常會碰到nohup command>/dev/null 2>&1 &這樣形式的命令。首先我們把這條命令大概分解下首先就是一個nohup表示當前使用者和系統的回話下的進城忽略響應HUP訊息。&是把該命令以後臺的job的形式執行。那麼就剩下command>/dev/null 2>&1,command>/dev/null較好理解,/dev/null表示一個空裝置,就是說吧command的執行結果重定向到空裝置中,說白了就是不顯示任何資訊。那麼2>&1又是什麼含義?
2>&1
幾個基本符號及其含義
/dev/null 表示空裝置檔案
0 表示stdin標準輸入
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的效率更高。
nohup結合
我們經常使用nohup command &
命令形式來啟動一些後臺程式,比如一些java服務:
nohup java -jar xxxx.jar &nohup java -jar xxxx.jar &
為了不讓一些執行資訊輸出到前臺(控制檯),我們還會加上剛才提到的>/dev/null 2>&1
命令來丟棄所有的輸出:
# nohup java -jar xxxx.jar >/dev/null 2>&1 &