20120520 shell編程之2>&1

文章摘自:http://hi.baidu.com/zxsz4085/blog/item/ad2986d56b3d331ea18bb7f9.html

經常可以在一些腳本,尤其是在crontab調用時發現如下形式的命令調用

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

要解釋這個問題,還是得提到文件重定向。

我們知道>和<是文件重定向符。那麼1和2是什麼?

在shell中,每個進程都和三個系統文件相關聯:

標準輸入stdin  文件描述符分別爲1

標準輸出stdout文件描述符分別爲2

標準錯誤stderr文件描述符分別爲3

所以這裏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無法執行的錯誤打印在屏幕上。

 

後面跟上2>&1


$ ./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的內容都也被重定向到log文件中了。

實際上,>就相當於1>(默認是標準輸出,所以可以省寫),也就是重定向標準輸出,不包括標準錯誤。

通過2>&1,就將標準錯誤重定向到標準輸出了,那麼再使用 > 重定向就會將標準輸出和標準錯誤信息一起重定向了。

如果只想重定向標準錯誤到文件中,則可以使用2>文件名。
 
 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章