0

0

Log4j2 RollingFile 仅保留最近4天日志的解决方案

霞舞

霞舞

发布时间:2025-12-27 19:25:12

|

449人浏览过

|

来源于php中文网

原创

Log4j2 RollingFile 仅保留最近4天日志的解决方案

log4j2 默认滚动策略会限制归档日志数量,若未显式配置 `defaultrolloverstrategy` 的 `max` 参数,其默认值为 7(但受 `filepattern` 中日期格式与目录结构影响,实际可能被误判为“按天归档+按序编号”,导致仅保留最近4个滚动单元)。本文详解如何通过正确配置 `defaultrolloverstrategy` 和归档清理策略,实现按日期目录归档并长期保留指定天数的日志。

Log4j2 的 RollingFileAppender 在触发滚动(如按大小或启动时)后,会根据 filePattern 生成新文件,并由 Rollover Strategy 决定如何管理旧日志——包括重命名、压缩、移动及自动删除过期文件。您当前配置中完全缺失 元素,因此 Log4j2 启用了默认策略:max = 7(即最多保留7个归档文件),且该计数基于滚动序列号 %i,而非日期。

但您的 filePattern 是:

filePattern="/mnt/logbackups/$${date:dd-MM-yyyy}/myservice-%d{dd-MM-yyyy}-%i.log.gz"

这会导致两个关键问题:

  1. $${date:dd-MM-yyyy} 是静态插值(仅在启动时计算一次),无法按天动态创建目录;
  2. %d{dd-MM-yyyy} 在 filePattern 中是归档时间占位符,但与 fileName 不匹配,且与 %i(索引)混用,使 Log4j2 将每个“日期+索引”组合视为独立归档单元,而默认 max=7 实际作用于整个归档池——当某天产生多个 %i 文件(如因频繁滚动),很快耗尽配额,旧文件被轮替删除,表现为“只留最近4天”。

✅ 正确做法是:明确声明 DefaultRolloverStrategy,并结合 Delete 行为按日期清理(推荐方式),或使用 DirectWriteRolloverStrategy(需 Log4j2 ≥ 2.19.0)。

Glean
Glean

Glean是一个专为企业团队设计的AI搜索和知识发现工具

下载

✅ 推荐方案:使用 Delete 归档清理策略(Log4j2 ≥ 2.5)

修改后的完整 RollingFile 配置如下(关键改动已加注释):


    filePattern="/mnt/logbackups/%d{yyyy-MM-dd}/myservice-%d{yyyy-MM-dd}-%i.log.gz">
    
        %d{yyyy-MM-dd HH:mm:ss.SSS} %-5p (%t) %c{1.} %m%n
    
    
        
        
        
        
    
    
    
        
        
            
            
            
            
                
                
                    
                
            
        
    

? 关键说明

  • basePath="/mnt/logbackups":指定清理根路径;
  • maxDepth="2":允许遍历子目录(如 /mnt/logbackups/2024-05-01/);
  • :删除最后修改时间早于7天的目录(即保留最近7天);
  • 确保只匹配目录(Unix风格),避免误删日志文件;
  • 务必先启用 testMode="true" 测试(如 ),确认日志输出中显示“Would delete…”而非实际删除。

⚠️ 注意事项

  • $$ 是错误写法,应为 $($${date:...} 中的 $ 是变量引用符号,$$ 会被转义为单 $,导致路径解析失败);
  • fileName 必须是当前活动日志的绝对路径,不可含日期占位符;
  • 若需严格按“年/月/日”三级目录,将 filePattern 改为:
    "/mnt/logbackups/%d{yyyy}/%d{MM}/%d{dd}/myservice-%d{yyyy-MM-dd}-%i.log.gz",并同步调整 Delete 的 basePath 和过滤逻辑;
  • TimeBasedTriggeringPolicy 与 OnStartupTriggeringPolicy 可共存,确保每天至少滚动一次(即使无新日志)。

通过以上配置,您将彻底解决“仅保留4天”的问题,并实现可预测、可审计的日志生命周期管理。

相关专题

更多
数据库Delete用法
数据库Delete用法

数据库Delete用法:1、删除单条记录;2、删除多条记录;3、删除所有记录;4、删除特定条件的记录。更多关于数据库Delete的内容,大家可以访问下面的文章。

265

2023.11.13

drop和delete的区别
drop和delete的区别

drop和delete的区别:1、功能与用途;2、操作对象;3、可逆性;4、空间释放;5、执行速度与效率;6、与其他命令的交互;7、影响的持久性;8、语法和执行;9、触发器与约束;10、事务处理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

205

2023.12.29

unix和linux的区别
unix和linux的区别

unix和linux的区别包括发展历史、开源性、发行版本、内核、文件系统、应用程序兼容性和用户界面等。本专题为大家提供unix和linux相关的文章、下载、课程内容,供大家免费下载体验。

379

2023.09.22

ip地址修改教程大全
ip地址修改教程大全

本专题整合了ip地址修改教程大全,阅读下面的文章自行寻找合适的解决教程。

35

2025.12.26

压缩文件加密教程汇总
压缩文件加密教程汇总

本专题整合了压缩文件加密教程,阅读专题下面的文章了解更多详细教程。

18

2025.12.26

wifi无ip分配
wifi无ip分配

本专题整合了wifi无ip分配相关教程,阅读专题下面的文章了解更多详细教程。

46

2025.12.26

漫蛙漫画入口网址
漫蛙漫画入口网址

本专题整合了漫蛙入口网址大全,阅读下面的文章领取更多入口。

94

2025.12.26

b站看视频入口合集
b站看视频入口合集

本专题整合了b站哔哩哔哩相关入口合集,阅读下面的文章查看更多入口。

289

2025.12.26

俄罗斯搜索引擎yandex入口汇总
俄罗斯搜索引擎yandex入口汇总

本专题整合了俄罗斯搜索引擎yandex相关入口合集,阅读下面的文章查看更多入口。

372

2025.12.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Java 教程
Java 教程

共578课时 | 38.5万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号