我想在我的log4j2.xml配置文件中定义1个单独的Appender,并使用Log4J2的属性替换的魔力,能够以某种方式登录到2个不同的文件。
我想Appender看起来像是:
<RollingFile name="Rolling-${filename}" fileName="${filename}" filePattern="${filename}.%i.log.gz">
<PatternLayout>
<pattern>%d %p %c{1.} [%t] %m%n</pattern>
</PatternLayout>
<SizeBasedTriggeringPolicy size="500" />
</RollingFile>
Logger是否有办法使用此appender并传递filename属性?
或者当我们使用LogManager.getLogger获取Logger时,有没有办法传递它?
请注意,这些记录器可能在同一个线程中,也可能不在同一个线程中,它必须支持这两种情况,因此我认为不可能使用ThreadContext或System属性。
答案 0 :(得分:0)
我能想到的最接近的是RoutingAppender。 RoutingAppender允许根据某些查找中的值动态选择日志文件。一个流行的内置查找是ThreadContext映射(请参阅example on the FAQ页面),但您可以创建自定义查找。示例代码:
ThreadContext.put("ROUTINGKEY", "foo");
logger.debug("This message gets sent to route foo");
// Do some work, including logging by various loggers.
// All logging done in this thread is sent to foo.
// Other threads can also log to foo at the same time by setting ROUTINGKEY=foo.
logger.debug("... and we are done");
ThreadContext.remove("ROUTINGKEY"); // this thread no longer logs to foo
动态创建日志文件的示例配置:
<Routing name="Routing">
<Routes pattern="$${ctx:ROUTINGKEY}">
<!-- This route is chosen if ThreadContext has a value for ROUTINGKEY.
The value dynamically determines the name of the log file. -->
<Route>
<RollingFile name="Rolling-${ctx:ROUTINGKEY}" fileName="logs/other-${ctx:ROUTINGKEY}.log"
filePattern="./logs/${date:yyyy-MM}/${ctx:ROUTINGKEY}-other-%d{yyyy-MM-dd}-%i.log.gz">
<PatternLayout>
<pattern>%d{ISO8601} [%t] %p %c{3} - %m%n</pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="6" modulate="true" />
<SizeBasedTriggeringPolicy size="10 MB" />
</Policies>
</RollingFile>
</Route>
</Routes>
<!-- This route is chosen if ThreadContext has no value for key ROUTINGKEY. -->
<Route key="$${ctx:ROUTINGKEY}">
<RollingFile name="Rolling-default" fileName="logs/default.log"
filePattern="./logs/${date:yyyy-MM}/default-%d{yyyy-MM-dd}-%i.log.gz">
<PatternLayout>
<pattern>%d{ISO8601} [%t] %p %c{3} - %m%n</pattern>
</PatternLayout>
<Policies>
<TimeBasedTriggeringPolicy interval="6" modulate="true" />
<SizeBasedTriggeringPolicy size="10 MB" />
</Policies>
</RollingFile>
</Route>
</Routing>
另一种方法是配置多个记录器,每个记录器指向一个单独的appender(additivity =“false”)。这允许您的应用程序通过其名称获取记录器来控制目标文件。但是,在这种情况下,您需要配置单独的appender,因此这不符合您的要求,我提到它是为了完整性。
答案 1 :(得分:0)
我正在使用记录器名称将参数传递给appender。
它的hacky但它有效:
LogManager.getLogger("com.company.test.Test.logto.xyz.log")
从记录器名称中提取文件名需要自定义StrLookup。