繁体   English   中英

log4j xml配置问题

[英]Problem with log4j xml configuration

我有一点疑问,我的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-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上进行记录时,它首先将追加器添加到直接与此记录器关联的追加器,然后向上传播。 com没有关联的附加程序,但root (所有记录器的父级)具有关联。 碰巧的是,它是同一控制台附加程序,因此它被附加了两次。

另一个可能的答案:( 假设您的示例从更复杂的记录器/附加器方案简化了

您可以将每个记录器的可additivity请参见“ Appenders和布局”部分 )属性设置为false 这将防止日志事件传播记录器层次结构。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM