springboot项目使用nohup将日志指定输出文件过大问题及解决办法

 更新时间:2024年10月12日 09:37:25   作者:z不像程序员的程序猿  
在Spring Boot项目中,使用nohup命令重定向日志输出到文件可能会使日志文件过大,文章介绍了两种解决方法:一是创建脚本直接清除日志文件,二是创建脚本保留部分日志内容,并将这些脚本加入定时任务中,这可以有效控制日志文件的大小,避免占用过多磁盘空间

springboot项目使用nohup将日志指定输出文件过大解决办法

假设目前有一个start.sh文件,内容为以下:

#!/bin/sh
jarname='app-gmt'
pid=`ps aux | grep $jarname | grep -v grep | grep java | awk '{print $2}'`
if [ "$pid" == "" ]
  then
        echo $jarname"进程不存在, 直接启动"$jarname"系统"
  else
        echo  "准备杀掉"$jarnamed"进程: "$pid
        kill -9 $pid
fi
nohup java -jar $jarname.jar --spring.profiles.active=online -server -Xms512m -Xmx1024m -Xss256k >> ./run.log 2>&1 &
echo "start success!!!"

注意看 nohup … >> ./run.log 2>&1 & 这一行,这里是将该进程的日志全部输出到指定的文件里,应该有不少人是这么做的。

那么这样做会出现一种情况,就是run.log会越来越大,直到爆炸。

该怎么解决呢?

一共分为两个步骤:

1.先创建一个清理日志文件的脚本
	1.直接清除方式
	2.保留部分方式
2.再创建一个定时任务(比如凌晨五点执行一次脚本)

下面对这两部进行细说:

第一点:这点其实是要看个人的具体需求的,比如清除的条件,可以是文件达到多大进行处理,处理时有的会保留一部分,有的会全清掉。

1.先说直接清除方式:

先创建一个脚本文件,内容如下:

#!/bin/bash
# 设置文件路径
FILE_PATH="/home/program/app/run.log"
# 设置文件大小阈值,单位为字节
THRESHOLD_SIZE=$((100 * 1024 * 1024))
# 获取文件大小
FILE_SIZE=$(du -b "$FILE_PATH" | cut -f1)
# 检查文件是否超过阈值
if [ $FILE_SIZE -gt $THRESHOLD_SIZE ]; then
    # 文件超过阈值,清空文件内容
    echo -n > "$FILE_PATH"
    echo "File has been cleaned up."
else
    echo "File size is within threshold."
fi

如果日志文件达到了100M,就清空文件内容。
记得把FILE_PATH改为你自己的日志文件路径

然后加入到定时任务:

crontab -e

内容如下:

0 5 * * * /data/log_clean/clean_app_log_file.sh

记得把路径替换成你自己的文件路径

2.保留部分方式

还是创建一个脚本文件:

log=`tail -n 10000 nohup.out`; 
echo "$log" > /home/program/app/run.log

记得把路径换成你自己的日志文件路径

然后创建定时任务,跟直接清除方式一样。

到此这篇关于springboot项目使用nohup将日志指定输出文件过大解决办法的文章就介绍到这了,更多相关springboot nohup文件过大内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java 运算符详情

    Java 运算符详情

    这篇文章主要介绍了Java 运算符,Java 中的运算符与 C 语言基本一致。下面文章就围绕Java 中的运算符的相关资料展开内容,需要的朋友可以参考一下
    2021-11-11
  • Javaweb中Request获取表单数据的四种方法详解

    Javaweb中Request获取表单数据的四种方法详解

    本文主要介绍了Javaweb中Request获取表单数据的四种方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • Java中父类怎么调用子类的方法

    Java中父类怎么调用子类的方法

    这篇文章主要介绍了Java父类调用子类的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • 反射机制:getDeclaredField和getField的区别说明

    反射机制:getDeclaredField和getField的区别说明

    这篇文章主要介绍了反射机制:getDeclaredField和getField的区别说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-06-06
  • Java 中的控制反转(IOC)详解

    Java 中的控制反转(IOC)详解

    这篇文章主要介绍了理解Java 中的IOC控制反转,具有一定参考价值,需要的朋友可以了解下,希望能够给你带来帮助
    2021-10-10
  • Java:详解Java中的异常

    Java:详解Java中的异常

    这篇文章主要介绍了java中的异常,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2021-08-08
  • myeclipse开发servlet_动力节点Java学院整理

    myeclipse开发servlet_动力节点Java学院整理

    MyEclipse,是在eclipse基础上加上自己的插件开发而成的功能强大的企业级集成开发环境,主要用于Java、Java EE以及移动应用的开发。下面这篇文章主要给大家介绍了关于myeclipse开发servlet的相关资料,需要的朋友可以参考下。
    2017-07-07
  • Mybatis分页插件PageHelper的使用详解

    Mybatis分页插件PageHelper的使用详解

    这篇文章主要介绍了Mybatis分页插件PageHelper的相关资料,该插件目前支持Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库分页需要的朋友可以参考下
    2016-12-12
  • spring boot devtools在Idea中实现热部署方法

    spring boot devtools在Idea中实现热部署方法

    这篇文章主要介绍了spring boot devtools在Idea中实现热部署方法及注意要点,需要的朋友可以参考下
    2018-02-02
  • springboot下mybatis-plus开启打印sql日志的配置指南

    springboot下mybatis-plus开启打印sql日志的配置指南

    这篇文章主要给大家介绍了关于springboot下mybatis-plus开启打印sql日志的配置指南的相关资料,还介绍了关闭打印的方法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2023-03-03

最新评论