nohup 日誌重定向

nohup command > nohup.log 2>&1 &

以下來自:https://www.cnblogs.com/zhangwuji/p/8059539.html

侵權刪

用途:不掛斷地運行命令。
語法:nohup Command [ Arg ... ] [ & ]
描述:nohup 命令運行由 Command 參數和任何相關的 Arg 參數指定的命令,忽略所有掛斷(SIGHUP)信號。在註銷後使用 nohup 命令運行後臺中的程序。要運行後臺中的 nohup 命令,添加 & ( 表示“and”的符號)到命令的尾部。

操作系統中有三個常用的流:
  0:標準輸入流 stdin
  1:標準輸出流 stdout
  2:標準錯誤流 stderr

      一般當我們用 > console.txt,實際是 1>console.txt的省略用法;< console.txt ,實際是 0 < console.txt的省略用法。

示例用法1:nohup ./start-dishi.sh >output 2>&1 &

解釋:
1. 帶&的命令行,即使terminal(終端)關閉,或者電腦死機程序依然運行(前提是你把程序遞交到服務器上); 

2. 2>&1的意思

  這個意思是把標準錯誤(2)重定向到標準輸出中(1),而標準輸出又導入文件output裏面,所以結果是標準錯誤和標準輸出都導入文件output裏面了。 至於爲什麼需要將標準錯誤重定向到標準輸出的原因,那就歸結爲標準錯誤沒有緩衝區,而stdout有。這就會導致 >output 2>output 文件output被兩次打開,而stdout和stderr將會競爭覆蓋,這肯定不是我門想要的. 這就是爲什麼有人會寫成: nohup ./command.sh >output 2>output出錯的原因了 。

 

      0,1,2可以用來指定需要重定向的標準輸入或輸出。在一般使用時,默認的是標準輸出,既1。當我們需要特殊用途時,可以使用其他標號。例如,將某個程序的錯誤信息輸出到log文件中:./program 2>log,這樣標準輸出還是在屏幕上,但是錯誤信息會輸出到log文件中。另外,也可以實現0,1,2之間的重定向。2>&1:將錯誤信息重定向到標準輸出。
      Linux下還有一個特殊的文件/dev/null,它就像一個無底洞,所有重定向到它的信息都會消失得無影無蹤,任何東西都可以定向到這裏,但是卻無法打開。這一點非常有用,一般很大的stdou和stderr當你不關心的時候或者當我們由於其他原因不需要回顯程序的所有信息時,就可以將輸出重定向到/dev/null。

例如:

# ls 1>/dev/null 2>/dev/null

還有一種做法是將錯誤重定向到標準輸出,然後再重定向到 /dev/null,例如:

# ls >/dev/null 2>&1

注意:此處的順序不能更改,否則達不到想要的效果,此時先將標準輸出重定向到 /dev/null,然後將標準錯誤重定向到標準輸出,由於標準輸出已經重定向到了/dev/null,因此標準錯誤也會重定向到/dev/null。

     

      由於使用nohup時,會自動將輸出寫入nohup.out文件中,如果文件很大的話,nohup.out就會不停的增大,這是我們不希望看到的,因此,可以利用/dev/null來解決這個問題。

# nohup ./program >/dev/null 2>log &

如果錯誤信息也不想要的話:

# nohup ./program >/dev/null 2>&1 &

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