linux下nohup日誌切割方案

  一、nohup命令解釋:shell

  a、語法:nohup [command] [args] [&]this

  b、說明:nohup 命令運行由 Command 參數和任何相關的 Arg 參數指定的命令,忽略全部掛斷信號。在註銷後使用 nohup 命令運行後臺中的程序。要運行後臺中的 nohup 命令,添加 & ( 表示「and」的符號)到命令的尾部,若是不指定重定向,則日誌默認輸出到當前目錄下nohup.out文件中,spa

  通常提交如 :nohup ./execute.sh &  這樣日誌或輸出當前運行目下.nohup.out中日誌

  重定向: nohup ./execute.sh >  /home/xxx/log.log 2>&1 & :這樣日誌會重定向到指定目錄下code

 2 、切分nohup.out,同時不讓它無限增加blog

 我這裏用的通常提交命令:nohup ./execute.sh &,這樣在當前目錄就有nohup.out文件了,這時候能夠想辦法定時將nohup.out切分紅,多個小文件,但同時又要使nohup.out不會無限增加下去(通常狀況下是程序不能中斷的):it

    a、天天(根據須要設置時間),定時切分前一天的日誌,(好比天天大概1g,那麼能夠麼次切分100m左右),class

    b、切分完後將nohup.out文件狀況,保證新的輸出日誌會不停的繼續輸出到nohup.out後臺

  以上在shell中百度

  current_date=`date -d "-1 day" "+%Y%m%d"`

   split  -b 65535000 -d -a 4  nohup.out  ./log/log_${current_date}_   這裏使用split命令,將nouhup文件按指定大小切分(65535000b 大概60多M吧,能夠自定義大小 ),並分紅指定格式(-d -a 4以4位數字形式爲後綴以從0000開始,具體能夠百度split命令用法),最終輸出格式爲log_20160610_0001

  cat /dev/null > nohup.out  (該命令會瞬間清空nohup.out文件,後續會繼續寫該文件),將日誌定向到/dev/null中

使用重定向輸出同樣能夠這樣,只不過換成重定向的文件名便可

將這些命令定義在一個shell文件天天定時運行便可,這樣天天日誌會被分紅若干份,排查也方便,並且若是日誌積壓過大的話。能夠定時刪除歷史的日誌,保留近幾天便可

總體代碼以下:

 

this_path=$(cd `dirname $0`;pwd) cd $this_path echo $this_path current_date=`date -d "-1 day" "+%Y%m%d"` echo $current_date split -b 65535000 -d -a 4 /home/.../nohup.out   /home/.../log/log_${current_date}_ cat /dev/null > nohup.out
相關文章
相關標籤/搜索