当前位置: 代码网 > 服务器>服务器>Linux > 解决Linux中nohup.out日志过大问题

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

2024年06月17日 Linux 我要评论
linux中nohup.out日志过大问题关于linux中nohup.out日志过大问题,可以通过设置定时任务来定期清理,具体操作是在nohup.out 所在目录创建一个clearnohup.sh 脚

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

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com