shell中,2>&1詳解


我們在Linux下經常會碰到nohup command>/dev/null 2>&1 &這樣形式的命令。首先我們把這條命令大概分解下,首先就是一個nohup表示當前用戶和系統的會話下的進城忽略響應HUP消息。&是把該命令以后台的job的形式運行。那么就剩下command>/dev/null 2>&1,command>/dev/null較好理解,/dev/null表示一個空設備,就是說把command的執行結果重定向到空設備中,說白了就是不顯示任何信息。那么2>&1又是什么含義?

幾個基本符號及其含義

  • /dev/null 表示空設備文件
  • 0 表示stdin標准輸入
  • 1 表示stdout標准輸出
  • 2 表示stderr標准錯誤
  • > 默認為標准輸出重定向,與 1> 相同
  • 2>&1 意思是把 標准錯誤輸出 重定向到 標准輸出
  • &>file 意思是把 標准輸出 和 標准錯誤輸出 都重定向到文件file中
  • >&file 意思是把 標准輸出 和 標准錯誤輸出 都重定向到文件file中

從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的效率更高。

舉個栗子

來個shell

test.sh
#!/bin/sh
t
date
chmod +x test.sh為test.sh增加執行權限。

 

這里我們弄了兩條命令,其中t指令並不存在,執行會報錯,會輸出到stderr。date能正常執行,執行會輸出當前時間,會輸出到stdout。

執行./test.sh > res1.log結果為:

我們發現stderr並沒有被重定向到res1.log中,stderr被打印到了屏幕上。這也進一步證明了上面說的./test.sh > res1.log等價於./test.sh 1>res1.log

驗證:./test.sh 1> res1.log

執行結果和上面一樣

 

執行./test.sh>res2.log 2>&1結果為:

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

 

&>file和>&file的意思都是是把 標准輸出 和 標准錯誤輸出 都重定向到文件file中

./test.sh &>res3.log

 

 ./test.sh >&res4.log

 

如果不想正確和錯誤的輸出,可以

./test.sh &>/dev/null 

 

另外

說明&后面可以有空格

 

說明只有正確的輸入到文件中了

 

說明>&之間不能有空格,報語法錯誤,也不會生成log文件

 

所以,最好:不要有空格,即:2>&1

 

部分內容參考:https://www.cnblogs.com/jimboi/p/8108241.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM