gpt4 book ai didi

java - Log4j2 : change filename dynamically in RollingFile Appender

转载 作者:太空宇宙 更新时间:2023-11-04 06:23:24 24 4
gpt4 key购买 nike

我正在使用 log4j2 和滚动文件附加程序,根据大小和时间滚动文件。这是我的配置文件和一个虚拟示例:

log4j2.xml

    <RollingFile name="RollingFile" filename="log/${date:dd-MM-yyyy-HH}/currentRoll.log"   filePattern="log/%d{dd-MM-yyyy-HH}/Roll-%i.log">
<PatternLayout>
<Pattern>%d{ISO8601}{GMT} %p %c{1.c} [%t] %m%n</Pattern>
</PatternLayout>

<Policies>
<TimeBasedTriggeringPolicy interval="1"/>
<SizeBasedTriggeringPolicy size="3KB"/>
</Policies>
</RollingFile>

<Console name="STDOUT" target="SYSTEM_OUT">
<PatternLayout>
<Pattern>%d{ISO8601}{GMT} [%t] %-5p %c{1}: %m%n</Pattern>
</PatternLayout>
</Console>

</Appenders>

<loggers>
<Root level="info">
<AppenderRef ref="Async"/>
</Root>
</loggers>
</Configuration>

和我的虚拟日志类:

public class Helloworld extends TimerTask {
private static final Logger logger=LogManager.getLogger("HelloWorld");


@Override
public void run(){
logger.info("fake info message");
logger.info("another fake info message");
}
}

我的问题是我当前的日志 (currentRoll.log) 文件位于首次创建的文件夹中节目开始了。我需要它放在最后。例如,如果我在 2014 年 11 月 25 日下午 1 点开始运行该程序,并且在下午 3 点我想查看当前日志,它们将不会位于 25-11-2014-15 文件夹中,而是位于 25-11-2014-13 文件夹中。

我的猜测是 ${date:dd-MM-yyyy-HH} 不是动态解析的。我尝试使用监视间隔轮询自动重新配置:

<Configuration status="info" name="MyApp" packages="" monitorInterval="5">

并使用“$$”,如下所示:$${date:dd-MM-yyyy-HH}但这给了我以下错误:

"2014-11-26 17:22:27,143 ERROR Unable to create file log/${date:dd-MM-yyyy-HH-mm}/currentRoll.log java.io.IOException: The filename, directory name, or volume label syntax is incorrect

我知道 log4net 有一个 datePattern 参数可以解决这个问题,但我找不到 log4j2 的等效参数。

关于如何进行的任何建议?

最佳答案

用于滚动追加器的日期是在创建滚动日志文件时确定的。或者,用 log4j 术语来说,“整个 RollingFile 元素的解析被推迟到发生匹配为止”。也就是说,仅当滚动文件时,{date} 属性才会以指定的分辨率进行插值。

$$ 设施可用于许多属性,但我不确定 {date} 是否是其中之一。我有一种感觉,事实并非如此,在这种情况下,正在制作的文件规范将字面上包含“${date...}”。这可能是您所看到的错误的根源。

过去,我曾尝试通过附加程序文件名中的“$${sys:someProperty}”使用系统属性(您可以在“属性”部分设置默认值),但您必须确保在调用记录器之前设置有问题的系统属性,否则您可能会得到仅使用默认值的滚动文件。

请参阅 property substitution 上的 Log4J 文档对于我正在谈论的内容。

最终,我自己的解决方案可能需要以编程方式实现记录器,以便我可以更改日志文件的根名称,并将最终用户友好的属性抽象到一个简单的属性文件中,而不是在其上转储 XML 文件。

关于java - Log4j2 : change filename dynamically in RollingFile Appender,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27155363/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com