log4j xml配置问题

时间:2011-09-02 16:01:59

标签: java log4j

我没有什么问题,我的log4j.xml配置列在下面

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">

<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
    <appender name="console" class="org.apache.log4j.ConsoleAppender">
        <param name="Target" value="System.out" />
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%-5p %c{1} - %m%n" />
        </layout>
    </appender>
     <logger name="com.alsodeep">
        <level value="info" />
        <appender-ref ref="console" />
    </logger>  
    <logger name="org.springframework">
        <level value="error" />
        <appender-ref ref="console" />
    </logger>
    <root>
        <priority value="error" />
        <appender-ref ref="console" />
    </root>

</log4j:configuration>

当我在com.alsodeep包中调用log.info(“some info”)时,它打印出两次,例如

INFO  AspectExample - Call it before method
INFO  AspectExample - Call it before method
Hello
INFO  AspectExample - Call it after method
INFO  AspectExample - Call it after method
List content [[23, 243, 234, 23432]]
INFO  App - final
INFO  App - final

我对此感到困惑,我的log4j设置有什么问题。

PS当我从根元素中删除appender时,一切正常,我的日志信息只出现一次。

2 个答案:

答案 0 :(得分:5)

卸下:

<appender-ref ref="console" />
来自特定记录器的

并且只在根记录器中留下一个:

<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">
    <appender name="console" class="org.apache.log4j.ConsoleAppender">
        <param name="Target" value="System.out" />
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="%-5p %c{1} - %m%n" />
        </layout>
    </appender>
     <logger name="com.alsodeep">
        <level value="info" />
    </logger>  
    <logger name="org.springframework">
        <level value="error" />
    </logger>
    <root>
        <priority value="error" />
        <appender-ref ref="console" />
    </root>

</log4j:configuration>

您的配置有效,但是当您尝试在com.alsodeep上记录某些内容时,它首先会获得直接与此记录器关联的appender,然后向上传播。 com没有关联的appender,但是root(所有记录器的父级)都有。巧合的是,它是相同的控制台appender,因此它会被追加两次。

答案 1 :(得分:2)

另一个可能的答案:(假设你的例子是从更复杂的记录器/ appender方案简化

您可以将每个记录器的additivitysee the "Appenders and Layout" section)属性设置为false。这将阻止日志事件向上传播记录器层次结构。