log4j2 默认滚动策略会限制归档日志数量,若未显式配置 `defaultrolloverstrategy` 的 `max` 参数,其默认值为 7(但受 `filepattern` 中日期格式与目录结构影响,实际可能被误判为“按天归档+按序编号”,导致仅保留最近4个滚动单元)。本文详解如何通过正确配置 `defaultrolloverstrategy` 和归档清理策略,实现按日期目录归档并长期保留指定天数的日志。
Log4j2 的 RollingFileAppender 在触发滚动(如按大小或启动时)后,会根据 filePattern 生成新文件,并由 Rollover Strategy 决定如何管理旧日志——包括重命名、压缩、移动及自动删除过期文件。您当前配置中完全缺失
但您的 filePattern 是:
filePattern="/mnt/logbackups/$${date:dd-MM-yyyy}/myservice-%d{dd-MM-yyyy}-%i.log.gz"这会导致两个关键问题:
Log4j2 将每个“日期+索引”组合视为独立归档单元,而默认 max=7 实际作用于整个归档池——当某天产生多个 %i 文件(如因频繁滚动),很快耗尽配额,旧文件被轮替删除,表现为“只留最近4天”。✅ 正确做法是:明确声明 DefaultRolloverStrategy,并结合 Delete 行为按日期清理(推荐方式),或使用 DirectWriteRolloverStrategy(需 Log4j2 ≥ 2.19.0)。
修改后的完整 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
? 关键说明:
通过以上配置,您将彻底解决“仅保留4天”的问题,并实现可预测、可审计的日志生命周期管理。