[轉]Linux Shell 1>/dev/null 2>&1 含義

shell中可能常常能看到:echo log > /dev/null 2>&1linux

 

命令的結果能夠經過%>的形式來定義輸出

/dev/null :表明空設備文件
>  :表明重定向到哪裏,例如:echo "123" > /home/123.txt
1  :表示stdout標準輸出,系統默認值是1,因此">/dev/null"等同於"1>/dev/null"
2  :表示stderr標準錯誤
&  :表示等同於的意思,2>&1,表示2的輸出重定向等同於1

1 > /dev/null 2>&1 語句含義:
1 > /dev/null : 首先表示標準輸出重定向到空設備文件,也就是不輸出任何信息到終端,說白了就是不顯示任何信息。
2>&1 :接着,標準錯誤輸出重定向(等同於)標準輸出,由於以前標準輸出已經重定向到了空設備文件,因此標準錯誤輸出也重定向到空設備文件。shell

 

實例解析:測試

cmd >a 2>a 和 cmd >a 2>&1 爲何不一樣?
cmd >a 2>a :stdout和stderr都直接送往文件 a ,a文件會被打開兩遍,由此致使stdout和stderr互相覆蓋。
cmd >a 2>&1 :stdout直接送往文件a ,stderr是繼承了FD1的管道以後,再被送往文件a 。a文件只被打開一遍,就是FD1將其打開。

.net

二者的不一樣點在於:blog

cmd >a 2>a 至關於使用了FD一、FD2兩個互相競爭使用文件 a 的管道;
cmd >a 2>&1 只使用了一個管道FD1,但已經包括了stdout和stderr。
從IO效率上來說,cmd >a 2>&1的效率更高。繼承


常常能夠在一些腳本,尤爲是在crontab調用時發現以下形式的命令調用進程

/tmp/test.sh > /tmp/test.log 2>&1
前半部分/tmp/test.sh > /tmp/test.log很容易理解,那麼後面的2>&1是怎麼回事呢?crontab

要解釋這個問題,仍是得提到文件重定向。咱們知道>和<是文件重定向符。那麼1和2是什麼?get

在shell中,每一個進程都和三個系統文件 相關聯:標準輸入stdin,標準輸出stdout、標準錯誤stderr,三個系統文件的文件描述符分別爲0,一、2。因此這裏2>&1 的意思就是將標準錯誤也輸出到標準輸出當中。cmd

 

下面經過一個例子來展現2>&1有什麼做用:

$ cat test.sh
t
date
test.sh中包含兩個命令,其中t是一個不存在的命令,執行會報錯,默認狀況下,錯誤會輸出到stderr。date則能正確執行,而且輸出時間信息,默認輸出到stdout

./test.sh > test1.log
./test.sh: line 1: t: command not found

$ cat test1.log
Wed Jul 10 21:12:02 CST 2013


能夠看到,date的執行結果被重定向到log文件中了,而t沒法執行的錯誤則只打印在屏幕上。

$ ./test.sh > test2.log 2>&1

$ cat test2.log
./test.sh: line 1: t: command not found
Tue Oct 9 20:53:44 CST 2007
此次,stderr和stdout的內容都被重定向到log文件中了。

 

實際上, > 就至關於 1> 也就是重定向標準輸出,不包括標準錯誤。經過2>&1,就將標準錯誤重定向到標準輸出了,那麼再使用>重定向就會將標準輸出和標準錯誤信息一同重定向了。若是隻想重定向標準錯誤到文件中,則可使用2> file。

linux shell 中"2>&1"含義腳本是:
       nohup /mnt/Nand3/H2000G >/dev/null 2>&1 &

對於&1 更準確的說應該是文件描述符 1,而1 通常表明的就是STDOUT_FILENO,實際上這個操做就是一個dup2(2)調用.他標準輸出到all_result ,而後複製標準輸出到文件描述符2(STDERR_FILENO),其後果就是文件描述符1和2指向同一個文件表項,也能夠說錯誤的輸出被合併了,其中0 表示鍵盤輸入 1表示屏幕輸出 2表示錯誤輸出,把標準出錯重定向到標準輸出,而後扔到/DEV/NULL下面去。通俗的說,就是把全部標準輸出和標準出錯都扔到垃圾桶裏面。
       command >out.file 2>&1 &
       command >out.file是將command的輸出重定向到out.file文件,即輸出內容不打印到屏幕上,而是輸出到out.file文件中。 2>&1 是將標準出錯重定向到標準輸出,這裏的標準輸出已經重定向到了out.file文件,即將標準出錯也輸出到out.file文件中。最後一個& , 是讓該命令在後臺執行。
       
       試想2>1表明什麼,2與>結合表明錯誤重定向,而1則表明錯誤重定向到一個文件1,而不表明標準輸出;
換成2>&1,&與1結合就表明標準輸出了,就變成錯誤重定向到標準輸出.

       你能夠用
             ls 2>1測試一下,不會報沒有2文件的錯誤,但會輸出一個空的文件1;
             ls xxx 2>1測試,沒有xxx這個文件的錯誤輸出到了1中;
             ls xxx 2>&1測試,不會生成1這個文件了,不過錯誤跑到標準輸出了;
             ls xxx >out.txt 2>&1, 實際上可換成 ls xxx 1>out.txt 2>&1;重定向符號>默認是1,錯誤和輸出都傳到out.txt了。

爲什麼2>&1要寫在後面?
       command > file 2>&1 
        首先是command > file將標準輸出重定向到file中, 2>&1 是標準錯誤拷貝了標準輸出的行爲,也就是一樣被重定向到file中,最終結果就是標準輸出和錯誤都被重定向到file中。 
       command 2>&1 >file 
       2>&1 標準錯誤拷貝了標準輸出的行爲,但此時標準輸出仍是在終端。>file 後輸出才被重定向到file,但標準錯誤仍然保持在終端。

用strace能夠看到: 
1. command > file 2>&1 
這個命令中實現重定向的關鍵系統調用序列是: 
open(file) == 3 
dup2(3,1) 
dup2(1,2)

2. command 2>&1 >file 
這個命令中實現重定向的關鍵系統調用序列是: 
dup2(1,2) 
open(file) == 3 
dup2(3,1)

能夠考慮一下不一樣的dup2()調用序列會產生怎樣的文件共享結構。請參考APUE 3.10, 3.12 

 

 

參考推薦:

1>/dev/null 2>&1的含義

/dev/null 2>&1 解釋  

 

(原文地址:https://blog.csdn.net/ithomer/article/details/9288353)

相關文章
相關標籤/搜索