指令碼是:
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