Logback从根目录中排除记录器

时间:2016-04-21 23:06:43

标签: java logging logback

我有一些打包,我想分开记录。

<property name="A" value="com.a"/>
<property name="B" value="com.b"/>
<property name="C" value="com.c"/>

<logger name="${A}" level="DEBUG">
    <appender-ref ref="FILE_A"/>
</logger>

<logger name="${B}" level="DEBUG">
    <appender-ref ref="FILE_B"/>
</logger>

<logger name="${C}" level="DEBUG">
    <appender-ref ref="FILE_B"/> <!-- yes B -->
</logger>

<root level="DEBUG">      
    <-- used for other logs too ->
    <appender-ref ref="STDOUT"/>
    <appender-ref ref="ROOT_FILE"/>
</root>

所以我有FILE_A FILE_B和ROOT_FILE; ROOT_FILE包含由根记录器和A B和C记录器写入的信息。

如何从ROOT_FILE中排除FILE_A FILE_B信息?

或者换句话说我如何从根记录器中排除日志数据(com.c com.b com.a)?

1 个答案:

答案 0 :(得分:5)

additivitycom.a记录器的com.b标记设置为false。

<logger name="${A}" level="DEBUG" additivity="false">
     <appender-ref ref="FILE_A"/>
</logger>

现在记录在该记录器中的事件不会传播到父记录器(在您的情况下是根记录器)。

documentation