解决Linux中nohup.out日志过大问题

 更新时间:2024年05月29日 09:00:00   作者: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

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

最新评论