解決Linux中nohup.out日志過大問題
Linux中nohup.out日志過大問題
關于Linux中nohup.out日志過大問題,可以通過設置定時任務來定期清理,具體操作是在nohup.out 所在目錄創(chuàng)建一個ClearNohup.sh 腳本,通過定時任務執(zhí)行該腳本讓其每周清理一次,防止nohup文件過大。
#!/bin/bash # Author: Ljohn # Last Update: 2018.02.24 # Description: nohup.out 日志分割 this_path=$(cd `dirname $0`;pwd) #根據(jù)腳本所在路徑 current_date=`date -d "-1 day" "+%Y%m%d"` #列出時間 cd $this_path echo $this_path echo $current_date do_split () { [ ! -d logs ] && mkdir -p logs split -b 10m -d -a 4 ./nohup.out ./logs/nohup-${current_date} #切分10兆每塊至logs文件中,格式為:nohup-xxxxxxxxxx if [ $? -eq 0 ];then echo "Split is finished!" else echo "Split is Failed!" exit 1 fi } do_del_log() { find ./logs -type f -ctime +7 | xargs rm -rf #清理7天前創(chuàng)建的日志 cat /dev/null > nohup.out #清空當前目錄的nohup.out文件 } if do_split ;then do_del_log echo "nohup is split Success" else echo "nohup is split Failure" exit 2 fi # crontab -e 添加定時任務:每周第一天的1點執(zhí)行一次 #0 1 * * */1 /server/scripts/clearNohup.sh &>/dev/null
第二步執(zhí)行定時任務
crontab -e #添加定時任務:每周第一天的1點執(zhí)行一次
注意事項
如果想通過手動執(zhí)行該腳本來達到清理的目的,需要設置該腳本的權限為可執(zhí)行
如何處理nohup.out的文件過大
linux中使用nohup的方式啟動java程序導致控制臺的輸出會加載到nohup.out文件里,日積月累導致文件過大占用硬盤。
處理方法
創(chuàng)建清理文件clear.sh 內(nèi)容如下:
this_path=$(cd `dirname $0`;pwd) #根據(jù)腳本所在路徑 current_date=`date -d "-1 day" "+%Y%m%d"` #列出時間 cd $this_path echo $this_path echo $current_date do_split () { [ ! -d logs ] && mkdir -p logs #切分10兆每塊至logs文件中,格式為:nohup-xxxxxxxxxx ./logs/nohup-${current_date}表示當前目錄的logs可以自主修改 split -b 10m -d -a 4 nohup.out的文件位置 ./logs/nohup-${current_date} if [ $? -eq 0 ];then echo "Split is finished!" else echo "Split is Failed!" exit 1 fi } do_del_log() { #清理3天前創(chuàng)建的日志 ./logs表示當前目錄的logs可以自主修改 find ./logs -type f -ctime +3 | xargs rm -rf cat /dev/null > nohup.out的文件位置 #清空當前目錄的nohup.out文件 } if do_split ;then do_del_log echo "nohup 切割成功" else echo "nohup 切割失敗" exit 2 fi
在linux的crontab中添加任務
sudo /etc/init.d/cron start 啟動crontab sudo /etc/init.d/cron stop 停止crontab sudo /etc/init.d/cron status crontab狀態(tài) sudo /etc/init.d/cron restart 重啟crontab
在 vi /etc/crontab中添加任務
31 1 * * * root /data/clearNohup/clearPricenohup.sh &>/dev/null #每日1點31執(zhí)行 ,根據(jù)需要自行修改
整體像這樣
重啟crontab即可
可以測試一下 sh clear.sh &>/dev/null
總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Linux mysql-5.6如何實現(xiàn)重置root密碼
這篇文章主要介紹了Linux mysql-5.6如何實現(xiàn)重置root密碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-08-08linux操作系統(tǒng)原理 linux系統(tǒng)基礎教程
很多對linux操作系統(tǒng)有興趣的朋友想有一個深入的學習,本篇文章給大家詳細講解了linux操作系統(tǒng)的原理,希望能夠對你有所幫助。2018-01-01apache2.2和php5.2.17在windows下整合過程的錯誤解決方法
照理來說apache和php的整合應該是非常簡單的,apache下載windows安裝版本后一路next即可完成安裝,php下載解壓版本后直接解壓到指定目錄,然后在apache的配置文件httpd.conf的最后加入如下幾行即可2011-08-08