Log4j2 不会滚动日志文件



我正在用LWJGL3做一个游戏,并使用log4j2进行日志记录。我正在尝试设置我的记录器,它可以工作,但是每次执行程序时,它只会覆盖最新的.log文件,而不是压缩它然后覆盖最新的.log。我尝试设置 OnStartupTriggeringPolicy 的 minSize,因为它默认为 1,并且我的文件大小目前非常小,但这没有帮助。有没有人知道如何让它工作。

log4j2.xml

<Configuration status="WARN">
<Appenders>
<Console name="Console" target="SYSTEM_OUT">
<PatternLayout pattern="%d{YYYY-MM-dd HH:mm:ss} [%level] [%t] - %msg%n" />
</Console>
<RollingFile name="RollingFile" filename="log/latest.log"
filePattern="${logPath}/%d{YYYYMMddHHmmss}.log.gz"
append="false">
<PatternLayout pattern="%d{YYYY-MM-dd HH:mm:ss} [%level] [%t] - %msg%n" />
<Policies>
<OnStartupTriggeringPolicy minSize="0"/>
<SizeBasedTriggeringPolicy size="250 MB"/>
</Policies>
<DefaultRolloverStrategy max="8"/>
</RollingFile>
</Appenders>
<Loggers>
<Root level="info">
<AppenderRef ref="Console" />
<AppenderRef ref="RollingFile" />
</Root>
</Loggers>
</Configuration>

您是否尝试过添加:

<TimeBasedTriggeringPolicy interval="1" modulate="true"/>

以下是我目前在项目中使用的 log4j2 配置示例。

<RollingFile name="file-log" fileName="${log-path}/autodeployer.log"
filePattern="${log-path}/autodeployer-%d{yyyy-MM-dd}-%i.log">
<PatternLayout>
<Pattern>${LOG_PATTERN}</Pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="1" modulate="true"/>
<SizeBasedTriggeringPolicy size="50MB"/>
</Policies>
<DefaultRolloverStrategy max="20"/>
</RollingFile>

最新更新