additivity="false" 与root关系

我在log4j.xml文件中配置了多个appender,但在logger中使用的时候,如果没有在<root>标签中配置有的appender,根本不生效。但是如果在<root>中配置了,而在logger中都没有配置的appender也会调用到。这会导致日志重复输出。求大虾指点,如何可以是一个logger只调用其中的某个appender?

 

将logger中的 additivity 属性配置为 false,则这个logger不会将日志流反馈到root中。

可以达到以logger中配置的appender方式来输出日志而其他地方输出的目的,看配置:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<appender name="DEMO" class="com.XXXXX.RollingFileAppender">
    <param name="file" value="${loggingRoot}/xxx.log" />
    <param name="append" value="true" />
    <param name="encoding" value="GB2312" />
    <param name="threshold" value="info" />
    <param name="MaxFileSize" value="50MB" />
    <param name="MaxBackupIndex" value="10" />
    <layout class="org.apache.log4j.PatternLayout">
        <param name="ConversionPattern" value="%d [%X{requestURIWithQueryString}] %-5p %c{2} - %m%n" />
    </layout>
</appender>
<logger name="XXXX.XXXX.XXXX" additivity="false">
    <level value="${loggingLevel}" />
    <appender-ref ref="DEMO" />
</logger>

root的作用是收集下面所有反馈上来的信息流并根据配置在root中appender进行输出,只要你在looger中配置了additivity="false",就不会反馈到root中。

posted on 2016-06-18 18:10  高达  阅读(11682)  评论(0)    收藏  举报

导航