解决Linux中nohup.out日志过大问题
作者:Mcband
这篇文章主要介绍了解决Linux中nohup.out日志过大问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
Linux中nohup.out日志过大问题
关于Linux中nohup.out日志过大问题,可以通过设置定时任务来定期清理,具体操作是在nohup.out 所在目录创建一个ClearNohup.sh 脚本,通过定时任务执行该脚本让其每周清理一次,防止nohup文件过大。
#!/bin/bash
# Author: Ljohn
# Last Update: 2018.02.24
# Description: nohup.out 日志分割
 
this_path=$(cd `dirname $0`;pwd)   #根据脚本所在路径
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天前创建的日志
    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点执行一次
#0 1 * * */1 /server/scripts/clearNohup.sh &>/dev/null
第二步执行定时任务
crontab -e #添加定时任务:每周第一天的1点执行一次
注意事项
如果想通过手动执行该脚本来达到清理的目的,需要设置该脚本的权限为可执行
如何处理nohup.out的文件过大
linux中使用nohup的方式启动java程序导致控制台的输出会加载到nohup.out文件里,日积月累导致文件过大占用硬盘。
处理方法
创建清理文件clear.sh 内容如下:
this_path=$(cd `dirname $0`;pwd) #根据脚本所在路径
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天前创建的日志   ./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状态 sudo /etc/init.d/cron restart 重启crontab
在 vi /etc/crontab中添加任务
31 1 * * * root /data/clearNohup/clearPricenohup.sh &>/dev/null #每日1点31执行 ,根据需要自行修改
整体像这样

重启crontab即可
可以测试一下 sh clear.sh &>/dev/null
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
