什么是 Logback 日志清理机制?
Logback 是 Java 社区广泛使用的日志框架,其强大的 RollingFileAppender 支持基于时间、文件大小等条件对日志进行滚动(归档),
并可通过配置自动删除过期或过多的日志文件,避免磁盘空间被无限占用。
常用滚动策略示例
以下是一个典型的 logback-spring.xml 配置,实现按天滚动并保留最近30天日志:
<configuration>
<appender name="FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>logs/app.log</file>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<fileNamePattern>logs/app.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<maxHistory>30</maxHistory>
<totalSizeCap>3GB</totalSizeCap>
<cleanHistoryOnStart>true</cleanHistoryOnStart>
</rollingPolicy>
<encoder>
<pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</pattern>
</encoder>
</appender>
<root level="info">
<appender-ref ref="FILE" />
</root>
</configuration>
关键配置说明
- maxHistory:保留日志文件的最大天数(或周期数),超出则自动删除。
- totalSizeCap:所有归档日志的总大小上限,超过后将删除最旧文件。
- cleanHistoryOnStart:应用启动时是否立即清理过期日志(默认 false)。
- 配合
%i可支持单日内多文件滚动(需搭配SizeAndTimeBasedRollingPolicy)。
最佳实践建议
- 始终设置 maxHistory 和 totalSizeCap 防止磁盘爆满。
- 在生产环境中启用 cleanHistoryOnStart 确保重启后及时释放空间。
- 定期审查日志策略,根据业务量调整保留周期。