我有一些打包,我想分开记录。
<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)?
答案 0 :(得分:5)
将additivity
和com.a
记录器的com.b
标记设置为false。
<logger name="${A}" level="DEBUG" additivity="false">
<appender-ref ref="FILE_A"/>
</logger>
现在记录在该记录器中的事件不会传播到父记录器(在您的情况下是根记录器)。