閱讀230 返回首頁    go 技術社區[雲棲]


《Log4j 2 官方文檔》Configuring Filters

配置過濾器

Log4j允許在下麵4個地方中任意一個指定過濾器:

  1. 與追加器,記錄器和屬性元素處於同一級別。 這些過濾器可以在事件傳遞到LoggerConfig之前接受或拒絕事件。
  2. 在記錄器元素中。 這些過濾器可以接受或拒絕特定記錄器的事件。
  3. 在一個appender元素。 這些過濾器可以防止或導致事件由追加器處理。
  4. 在追加器引用元素中。 這些過濾器用於確定記錄器是否應將事件路由到追加器。

雖然隻能配置單個 filter元素,但該元素可以是代表CompositeFilter的 filters元素。 filters 元素允許在其內配置任何數量的filter元素。下麵的例子表示如何在ConsoleAppender上配置多個過濾器。

<?xml version="1.0" encoding="UTF-8"?>
<Configuration status="debug" name="XMLConfigTest" packages="org.apache.logging.log4j.test">
  <Properties>
    <Property name="filename">target/test.log</Property>
  </Properties>
  <ThresholdFilter level="trace"/>

  <Appenders>
    <Console name="STDOUT">
      <PatternLayout pattern="%m MDC%X%n"/>
    </Console>
    <Console name="FLOW">
      <!-- this pattern outputs class name and line number -->
      <PatternLayout pattern="%C{1}.%M %m %ex%n"/>
      <filters>
        <MarkerFilter marker="FLOW" onMatch="ACCEPT" onMismatch="NEUTRAL"/>
        <MarkerFilter marker="EXCEPTION" onMatch="ACCEPT" onMismatch="DENY"/>
      </filters>
    </Console>
    <File name="File" fileName="${filename}">
      <PatternLayout>
        <pattern>%d %p %C{1.} [%t] %m%n</pattern>
      </PatternLayout>
    </File>
    <List name="List">
    </List>
  </Appenders>

  <Loggers>
    <Logger name="org.apache.logging.log4j.test1" level="debug" additivity="false">
      <ThreadContextMapFilter>
        <KeyValuePair key="test" value="123"/>
      </ThreadContextMapFilter>
      <AppenderRef ref="STDOUT"/>
    </Logger>

    <Logger name="org.apache.logging.log4j.test2" level="debug" additivity="false">
      <Property name="user">${sys:user.name}</Property>
      <AppenderRef ref="File">
        <ThreadContextMapFilter>
          <KeyValuePair key="test" value="123"/>
        </ThreadContextMapFilter>
      </AppenderRef>
      <AppenderRef ref="STDOUT" level="error"/>
    </Logger>

    <Root level="trace">
      <AppenderRef ref="List"/>
    </Root>
  </Loggers>

</Configuration>

轉載自 並發編程網 - ifeve.com

最後更新:2017-05-19 11:01:42

  上一篇:go  《Log4j官方文檔》 JSON配置
  下一篇:go  《Log4j 2 官方文檔》多餘性(Additivity)