我們在Linux下經常會碰到:
nohup command>/dev/null 2>&1 &
這樣形式的命令。
我們把這條命令大概分解一下。
(1)首先,就是一個nohup表示當前用戶和系統的會話下的進程忽略響應HUP消息,也就是不掛斷地運行命令。
(2)& 符號是把該命令以后台的job的形式運行。
(3)那么就剩下command>/dev/null 2>&1,其中command>/dev/null較好理解,/dev/null表示一個空設備,就是把 command的執行結果重定向到空設備中,說白了就是不顯示任何信息。
(4)最后,2>&1又是什么含義?
2>&1 幾個基本符號及其含義
- /dev/null 表示空設備文件
- 0 表示stdin標准輸入
- 1 表示stdout標准輸出
- 2 表示stderr標准錯誤
command > /dev/null相當於執行了command 1 > /dev/null。執行command產生了標准輸出stdout(用1表示),重定向到/dev/null的設備文件中。
分析 2>&1
對於2>&1的理解,2就是標准錯誤,1是標准輸出,那么這條命令不就是相當於把標准錯誤重定向到標准輸出么?是的。
為什么是&1而不是1,這里& 符號是什么?& 符號可以理解為引用(reference)。&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的效率更高。
演示一下效果
//test.sh shell 程序
#!/bin/sh
t
date
其中t指令並不存在,執行會報錯,會輸出到stderr。date能正常執行,執行會輸出當前時間,會輸出到stdout。

chmod +x test.sh為test.sh增加執行權限。

執行 ./test.sh > test.log,如下所示:

我們發現 stderr 並沒有被重定向到 test.log 中,stderr 直接輸出到屏幕上了。
執行 ./test.sh > test.log 2>&1,如下所示:

這次,我們發現stdout 和 stderr 都被重定向到了 test.log 中了。