idea工作台输出的日志详解_详解linux下nohup日志输出过大问题解决方案--分批切割...
概述
有的時候我們為了讓某個程序在后臺跑,一般都會用nohup ./xxx & 執行讓程序后臺運行,假設過了一段時間日志就上G了,如果有問題想要查看日志,顯然打開文件是一件很麻煩的事,有什么辦法可以減小文件大小呢?
nohup命令解釋:
語法:
nohup [command] [args] [&]說明:nohup 命令運行由 Command 參數和任何相關的 Arg 參數指定的命令,忽略所有掛斷信號。在注銷后使用 nohup 命令運行后臺中的程序。要運行后臺中的 nohup 命令,添加 & ( 表示“and”的符號)到命令的尾部,如果不指定重定向,則日志默認輸出到當前目錄下nohup.out文件中,
重定向: nohup ./execute.sh > /home/xxx/log.log 2>&1 & :這樣日志會重定向到指定目錄下。
nohup和&的區別
& : 指在后臺運行
nohup : 不掛斷的運行,注意并沒有后臺運行的功能,,就是指,用nohup運行命令可以使命令永久的執行下去,和用戶終端沒有關系,例如我們斷開SSH連接都不會影響他的運行,注意了nohup沒有后臺運行的意思;&才是后臺運行
切分nohup.out,不讓它無限增長
思路:定時將nohup.out切分成,多個小文件,但同時又要使nohup.out不會無限增長下去(一般情況下是程序不能中斷的)。
a、每天(根據需要設置時間),定時切分前一天的日志,(比如每天大概1g,那么可以么次切分100m左右),
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開始),最終輸出格式為log_20190918_0001
cat /dev/null > nohup.out
(該命令會瞬間清空nohup.out文件,后續會繼續寫該文件),將日志定向到/dev/null中
使用重定向輸出一樣可以這樣,只不過換成重定向的文件名即可
將這些命令定義在一個shell文件每天定時運行即可,這樣每天日志會被分成若干份,排查也方便,而且如果日志積壓過大的話??梢远〞r刪除歷史的日志,保留近幾天即可。
最終腳本如下:
#!/bin/bashpath=$(cd `dirname $0`;pwd) cd $pathecho $pathcurrent_date=`date -d "-1 day" "+%Y%m%d"`echo $current_datesplit -b 65535000 -d -a 4 /home/nohup.out /home/log/log_${current_date}_cat /dev/null > nohup.out覺得有用的朋友多幫忙轉發哦!后面會分享更多devops和DBA方面的內容,感興趣的朋友可以關注下~
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的idea工作台输出的日志详解_详解linux下nohup日志输出过大问题解决方案--分批切割...的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 角色扮演游戏《中国式相亲 2》登陆 St
- 下一篇: linux配置ip地址 suse_sus