相同的Appender使用Log4J2

时间:2015-05-21 23:28:17

标签: configuration log4j2

我想在我的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属性。

2 个答案:

答案 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。