標籤:blog http ar 使用 sp strong 檔案 div on
http://blog.csdn.net/gyanp/article/details/7258356
經常可以在一些指令碼,尤其是在crontab調用時發現如下形式的命令調用
/tmp/test.sh > /tmp/test.log 2>&1
前半部分/tmp/test.sh > /tmp/test.log很容易理解,那麼後面的2>&1是怎麼回事呢?
要解釋這個問題,還是得提到檔案重新導向。我們知道>和<是檔案重新導向符。那麼1和2是什嗎?
在shell中,每個進程都和三個系統檔案相關聯:標準輸入stdin,標準輸出stdout和標準錯誤stderr,三個系統檔案的檔案描述符分別為0,1和2。所以這裡2>&1 的意思就是將標準錯誤也輸出到標準輸出當中。
下面通過一個例子來展示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
Tue Oct 9 20:51:50 CST 2007
可以看到,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。
如:
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檔案中。最後一個& , 是讓該命令在後台執行。
shell 編程之2>&1含義