230
技術社區[雲棲]
《Log4j 2 官方文檔》Configuring Filters
配置過濾器
Log4j允許在下麵4個地方中任意一個指定過濾器:
- 與追加器,記錄器和屬性元素處於同一級別。 這些過濾器可以在事件傳遞到LoggerConfig之前接受或拒絕事件。
- 在記錄器元素中。 這些過濾器可以接受或拒絕特定記錄器的事件。
- 在一個appender元素。 這些過濾器可以防止或導致事件由追加器處理。
- 在追加器引用元素中。 這些過濾器用於確定記錄器是否應將事件路由到追加器。
雖然隻能配置單個 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>
最後更新:2017-05-19 11:01:42