• CentOS系统上定时备份与清理Java项目日志文件


    前言

    在开发和维护Java项目时,日志文件是关键的调试和故障排查工具。然而,随着时间的推移,日志文件可能会不断增长,导致文件过大,降低了系统的性能并且难以管理。为了解决这个问题,我们将介绍如何在CentOS系统上实现定时备份与清理Java项目日志文件的方案。

    步骤

    1、设置定时器(两种方式)

    方式一:Java项目中设置定时器

    首先,在Java项目的主启动类中添加@EnableScheduling注解,以启用定时器功能。示例代码如下:

    @SpringBootApplication
    @EnableScheduling
    public class SmartBootApplication {
        public static void main(String[] args) {
            SpringApplication.run(SmartBootApplication.class, args);
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    然后,在一个新建的类中作为定时器组件进行注入,以执行定时操作。示例代码如下:

    @Component
    public class TimingTask {
        @Scheduled(cron = "0 0 2 * * ?")
        public void dailyLogDeal() {
            try {
                Runtime.getRuntime().exec("/path/to/backup_script.sh").waitFor();
                System.out.println("定时任务执行 -> 每日日志备份与清理成功");
            } catch (InterruptedException | IOException e) {
                e.printStackTrace();
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    在上述代码中,我们使用了@Scheduled注解来指定定时器执行的时间,这里设置为每天凌晨2点执行一次服务器上的脚本/path/to/backup_script.sh

    方式二:CentOS系统设置定时任务

    首先,在CentOS系统上安装Cron服务,该服务可用于定时执行任务。打开终端,使用以下命令安装Cron:

    sudo yum install cronie
    
    • 1

    安装完成后,使用以下命令启动和设置Cron服务:

    sudo systemctl start crond
    sudo systemctl enable crond
    
    • 1
    • 2

    接下来,使用以下命令编辑Cron配置文件:

    crontab -e
    
    • 1

    在编辑器中,添加以下行来配置定时任务:

    0 2 * * * /bin/bash /path/to/backup_script.sh
    
    • 1

    保存并关闭配置文件。这将设置每天凌晨2点执行一次备份与清理脚本/path/to/backup_script.sh

    2、编写备份与清理脚本

    接下来,我们需要编写一个Shell脚本来实现日志备份和清理操作。示例脚本backup_script.sh内容如下:

    # 获取前一天的日期
    date=$(date -d "yesterday" +%Y_%m_%d)
    
    # 复制原始日志文件到备份目录,并以前一天的日期进行命名
    cp /path/to/your_log_file /path/to/backup_directory/$date.log
    
    # 清空原始日志文件内容
    cat /dev/null > /path/to/your_log_file
    
    # 清理一个月前的备份文件
    find /path/to/backup_directory -mtime +30 -exec rm -f {} \;
    
    # 创建日志备份目录(如果不存在)
    if [ ! -d /path/to/backup_directory ]; then
        mkdir /path/to/backup_directory
    fi
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    在上述脚本中,首先使用date命令获取前一天的日期,并将其作为备份文件名的一部分。然后使用cp命令将原始的日志文件复制到备份目录,并以前一天的日期命名备份文件。接着,使用cat命令清空原始的日志文件。最后,使用find命令清理一个月前的备份文件,并使用mkdir命令创建备份目录(如果不存在)。

    3、执行定时任务

    当定时器触发时,将会执行备份与清理脚本。由于已经在定时任务的代码中调用了Shell脚本,因此当定时任务执行时,会执行Shell脚本中的命令,完成备份和清理操作。

    通过以上步骤,我们实现了定时备份与清理Java项目日志文件的方案。采取这种策略可以及时维护日志文件,避免文件过大导致写入问题和程序报错。

    总结:

    通过设置定时器,结合Shell脚本的备份与清理操作,我们可以解决Java项目日志过大的问题。定时备份可以保留历史日志记录以供参考和排查问题,而清理操作可以防止日志文件过大导致的写入失败。定时备份与清理方案可以帮助我们有效管理日志文件,提高项目的稳定性和可维护性。

    结束语:外貌,决定有没有可能在一起;性格,决定适不适合在一起;物质,决定能不能稳定在一起;信任,决定能不能长久在一起

  • 相关阅读:
    007-JAVA循环语句详细介绍
    DNA脱氧核糖核酸修饰金属铂纳米颗粒PtNPS-DNA|科研试剂
    【机器学习】——【线性回归模型】——详细【学习路线】
    化合物应用 | 动物实验溶剂选择
    python应用(3):读取excel文件并导出为json文件
    【爬虫】实战-爬取Boss直聘信息数据
    华为云云耀云服务器L实例评测|Docker部署及应用
    【错误记录】IntelliJ IDEA 导出可执行 jar 包执行报错 ( java.lang.ClassNotFoundException | 打包时没有选择依赖库 )
    各种免费好用的api整理分享
    【算法刷题 | 栈】3.16(有效的括号、删除字符串中的所有相邻重复项、逆波兰表达式求值)
  • 原文地址:https://blog.csdn.net/Da_zhenzai/article/details/133683689