解決Linux中nohup.out日志過大問題
Linux中nohup.out日志過大問題
關(guān)于Linux中nohup.out日志過大問題,可以通過設(shè)置定時(shí)任務(wù)來定期清理,具體操作是在nohup.out 所在目錄創(chuàng)建一個(gè)ClearNohup.sh 腳本,通過定時(shí)任務(wù)執(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"` #列出時(shí)間 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 #清空當(dāng)前目錄的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 添加定時(shí)任務(wù):每周第一天的1點(diǎn)執(zhí)行一次 #0 1 * * */1 /server/scripts/clearNohup.sh &>/dev/null
第二步執(zhí)行定時(shí)任務(wù)
crontab -e #添加定時(shí)任務(wù):每周第一天的1點(diǎn)執(zhí)行一次
注意事項(xiàng)
如果想通過手動(dòng)執(zhí)行該腳本來達(dá)到清理的目的,需要設(shè)置該腳本的權(quán)限為可執(zhí)行
如何處理nohup.out的文件過大
linux中使用nohup的方式啟動(dòng)java程序?qū)е驴刂婆_(tái)的輸出會(huì)加載到nohup.out文件里,日積月累導(dǎo)致文件過大占用硬盤。
處理方法
創(chuàng)建清理文件clear.sh 內(nèi)容如下:
this_path=$(cd `dirname $0`;pwd) #根據(jù)腳本所在路徑 current_date=`date -d "-1 day" "+%Y%m%d"` #列出時(shí)間 cd $this_path echo $this_path echo $current_date do_split () { [ ! -d logs ] && mkdir -p logs #切分10兆每塊至logs文件中,格式為:nohup-xxxxxxxxxx ./logs/nohup-${current_date}表示當(dāng)前目錄的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表示當(dāng)前目錄的logs可以自主修改 find ./logs -type f -ctime +3 | xargs rm -rf cat /dev/null > nohup.out的文件位置 #清空當(dāng)前目錄的nohup.out文件 } if do_split ;then do_del_log echo "nohup 切割成功" else echo "nohup 切割失敗" exit 2 fi
在linux的crontab中添加任務(wù)
sudo /etc/init.d/cron start 啟動(dòng)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中添加任務(wù)
31 1 * * * root /data/clearNohup/clearPricenohup.sh &>/dev/null #每日1點(diǎn)31執(zhí)行 ,根據(jù)需要自行修改
整體像這樣
重啟crontab即可
可以測試一下 sh clear.sh &>/dev/null
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Ubuntu安裝Matlab2020b詳細(xì)教程和資源
大家好,本篇文章主要講的是Ubuntu安裝Matlab2020詳細(xì)教程和資源,感興趣的同學(xué)趕快來看一看吧,希望對你有幫助2021-11-11Linux mysql-5.6如何實(shí)現(xiàn)重置root密碼
這篇文章主要介紹了Linux mysql-5.6如何實(shí)現(xiàn)重置root密碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08linux操作系統(tǒng)原理 linux系統(tǒng)基礎(chǔ)教程
很多對linux操作系統(tǒng)有興趣的朋友想有一個(gè)深入的學(xué)習(xí),本篇文章給大家詳細(xì)講解了linux操作系統(tǒng)的原理,希望能夠?qū)δ阌兴鶐椭?/div> 2018-01-01apache2.2和php5.2.17在windows下整合過程的錯(cuò)誤解決方法
照理來說apache和php的整合應(yīng)該是非常簡單的,apache下載windows安裝版本后一路next即可完成安裝,php下載解壓版本后直接解壓到指定目錄,然后在apache的配置文件httpd.conf的最后加入如下幾行即可2011-08-08虛擬機(jī)Linux橋接模式下設(shè)置靜態(tài)IP詳解
這篇文章主要介紹了虛擬機(jī)Linux橋接模式下設(shè)置靜態(tài)IP詳解,小編覺得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-01-01詳解Linux系統(tǒng)配置nginx的負(fù)載均衡
這篇文章主要介紹了詳解Linux系統(tǒng)配置nginx的負(fù)載均衡的相關(guān)資料,這里對負(fù)載均衡的幾種方式進(jìn)行了講解并附NGINX配置文件,需要的朋友可以參考下2017-03-03最新評論