解決Linux中nohup.out日志過(guò)大問(wèn)題
Linux中nohup.out日志過(guò)大問(wèn)題
關(guān)于Linux中nohup.out日志過(guò)大問(wèn)題,可以通過(guò)設(shè)置定時(shí)任務(wù)來(lái)定期清理,具體操作是在nohup.out 所在目錄創(chuàng)建一個(gè)ClearNohup.sh 腳本,通過(guò)定時(shí)任務(wù)執(zhí)行該腳本讓其每周清理一次,防止nohup文件過(guò)大。
#!/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)
如果想通過(guò)手動(dòng)執(zhí)行該腳本來(lái)達(dá)到清理的目的,需要設(shè)置該腳本的權(quán)限為可執(zhí)行
如何處理nohup.out的文件過(guò)大
linux中使用nohup的方式啟動(dòng)java程序?qū)е驴刂婆_(tái)的輸出會(huì)加載到nohup.out文件里,日積月累導(dǎo)致文件過(guò)大占用硬盤。
處理方法
創(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即可
可以測(cè)試一下 sh clear.sh &>/dev/null
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Ubuntu安裝Matlab2020b詳細(xì)教程和資源
大家好,本篇文章主要講的是Ubuntu安裝Matlab2020詳細(xì)教程和資源,感興趣的同學(xué)趕快來(lái)看一看吧,希望對(duì)你有幫助2021-11-11
Linux mysql-5.6如何實(shí)現(xiàn)重置root密碼
這篇文章主要介紹了Linux mysql-5.6如何實(shí)現(xiàn)重置root密碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08
linux操作系統(tǒng)原理 linux系統(tǒng)基礎(chǔ)教程
很多對(duì)linux操作系統(tǒng)有興趣的朋友想有一個(gè)深入的學(xué)習(xí),本篇文章給大家詳細(xì)講解了linux操作系統(tǒng)的原理,希望能夠?qū)δ阌兴鶐椭?/div> 2018-01-01
apache2.2和php5.2.17在windows下整合過(guò)程的錯(cuò)誤解決方法
照理來(lái)說(shuō)apache和php的整合應(yīng)該是非常簡(jiǎn)單的,apache下載windows安裝版本后一路next即可完成安裝,php下載解壓版本后直接解壓到指定目錄,然后在apache的配置文件httpd.conf的最后加入如下幾行即可2011-08-08
虛擬機(jī)Linux橋接模式下設(shè)置靜態(tài)IP詳解
這篇文章主要介紹了虛擬機(jī)Linux橋接模式下設(shè)置靜態(tài)IP詳解,小編覺(jué)得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-01-01
詳解Linux系統(tǒng)配置nginx的負(fù)載均衡
這篇文章主要介紹了詳解Linux系統(tǒng)配置nginx的負(fù)載均衡的相關(guān)資料,這里對(duì)負(fù)載均衡的幾種方式進(jìn)行了講解并附NGINX配置文件,需要的朋友可以參考下2017-03-03最新評(píng)論

