Log4j:为什么根记录器收集所有日志类型而不管配置如何?

时间:2008-09-17 19:45:48

标签: java logging log4j

我遇到问题,即使我在根标记中指定了ERROR级别,指定的appender也会将所有级别(debug,info,warn)记录到文件中,而不管设置如何。我不是log4j专家,所以感谢任何帮助。

以下是有关该主题的更多信息:

  • 我已经检查了log4j.properties的类路径(没有),除了log4j.xml

这是log4j.xml文件:

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j='http://jakarta.apache.org/log4j/'>


    <!-- ============================== -->
    <!-- Append messages to the console -->
    <!-- ============================== -->


    <appender name="console" class="org.apache.log4j.ConsoleAppender">
        <param name="Target" value="System.out" />

        <layout class="org.apache.log4j.PatternLayout">
            <!-- The default pattern: Date Priority [Category] Message\n -->
            <param name="ConversionPattern" value="[AC - %5p] [%d{ISO8601}] [%t] [%c{1} - %L] %m%n" />
        </layout>
    </appender>

    <appender name="logfile" class="org.apache.log4j.RollingFileAppender">
        <param name="File" value="./logs/server.log" />
        <param name="MaxFileSize" value="1000KB" />
        <param name="MaxBackupIndex" value="2" />
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="[AC - %-5p] {%d{dd.MM.yyyy - HH.mm.ss}} %m%n" />
        </layout>
    </appender>

    <appender name="payloadAppender" class="org.apache.log4j.RollingFileAppender">
        <param name="File" value="./logs/payload.log" />
        <param name="MaxFileSize" value="1000KB" />
        <param name="MaxBackupIndex" value="10" />
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="[AC - %-5p] {%d{dd.MM.yyyy - HH.mm.ss}} %m%n" />
        </layout>
    </appender>

    <appender name="errorLog" class="org.apache.log4j.RollingFileAppender">
        <param name="File" value="./logs/error.log" />
        <param name="MaxFileSize" value="1000KB" />
        <param name="MaxBackupIndex" value="10" />
        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern" value="[AC - %-5p] {%d{dd.MM.yyyy - HH.mm.ss}} %m%n" />
        </layout>
    </appender>

    <appender name="traceLog"
        class="org.apache.log4j.RollingFileAppender">
        <param name="File" value="./logs/trace.log" />
        <param name="MaxFileSize" value="1000KB" />
        <param name="MaxBackupIndex" value="20" />

        <layout class="org.apache.log4j.PatternLayout">
            <param name="ConversionPattern"
                value="[AccessControl - %-5p] {%t: %d{dd.MM.yyyy - HH.mm.ss,SSS}} %m%n" />
        </layout>
    </appender>

    <appender name="traceSocketAppender" class="org.apache.log4j.net.SocketAppender">
        <param name="remoteHost" value="localhost" />
        <param name="port" value="4445" />
        <param name="locationInfo" value="true" />
    </appender>

    <logger name="TraceLogger">
        <level value="trace" /> <!-- Set level to trace to activate tracing -->
        <appender-ref ref="traceLog" />     
    </logger>

    <logger name="org.springframework.ws.server.endpoint.interceptor">
        <level value="DEBUG" />
        <appender-ref ref="payloadAppender" />
    </logger>

    <root>
        <level value="error" />
        <appender-ref ref="errorLog" />
    </root>

</log4j:configuration>

如果我用另一个记录器替换root,那么根本没有任何记录到指定的appender。

<logger name="com.mydomain.logic">
    <level value="error" />
    <appender-ref ref="errorLog" />
</logger>

...谢谢你们到目前为止的提示: - )

6 个答案:

答案 0 :(得分:72)

根记录器位于记录器层次结构的顶部。它在三个方面表现出色:

  • 它始终存在,
  • 其级别不能设为null
  • 无法通过名称检索。

rootLogger是所有appender的父亲。给定记录器的每个启用的日志记录请求都将转发到该记录器中的所有appender以及层次结构中较高的appender(包括rootLogger)

例如,如果将console appender添加到root logger,则所有已启用的日志记录请求将至少在控制台上打印。如果另外将文件追加器添加到记录器,例如L,则LL's子项的已启用记录请求将打印在文件console。可以覆盖此默认行为,以便通过将additivity标志设置为false 来使appender累积不再是

来自log4j手册

总结一下:

如果您不想将记录事件传播到父记录器(例如rootLogger),则在这些记录器中将additivity标志添加到false。在你的情况下:

<logger name="org.springframework.ws.server.endpoint.interceptor"
        additivity="false">
        <level value="DEBUG" />
        <appender-ref ref="payloadAppender" />
</logger>

在标准的log4j配置样式中(我更喜欢XML):

log4j.logger.org.springframework.ws.server.endpoint.interceptor = INFO, payloadAppender
log4j.additivity.org.springframework.ws.server.endpoint.interceptor = false

希望这有帮助。

答案 1 :(得分:8)

使用-Dlog4j.debug运行您的程序,以便标准输出获取有关如何配置log4j的信息 - 我怀疑它没有按照您认为的方式进行配置。

答案 2 :(得分:5)

再加上James AN Stauffer和愤世嫉俗者所说的 - 我敢打赌你的类路径上还有另一个log4j.xml / log4j.properties,而不是你希望使用的那个导致log4j以自己的方式配置它是。

-Dlog4j.debug是解决任何log4j问题的绝对杀手方式。

答案 3 :(得分:4)

两件事:检查可加性并决定是否希望更详细级别的日志记录捕获的日志事件传播到根记录器。

其次,检查根记录器的级别。此外,您还可以在appender本身上添加过滤,但通常不需要这样做。

答案 4 :(得分:2)

如果您使用的是log4j.properties文件,则通常希望此文件位于类路径的根目录中,因此请确保它在那里。

答案 5 :(得分:0)

这是正确的行为。根记录器就像默认行为一样。因此,如果您未指定任何记录器,则它将根记录器级别作为默认级别,但这并不意味着根记录器级别是所有日志的级别。

使用'TraceLogger'logger或'org.springframework.ws.server.endpoint.interceptor'记录器记录的任何代码都将使用TRACE和DEBUG级别分别记录消息,任何其他代码将使用root logger来记录消息使用级别,在你的情况下是ERROR。

因此,如果您使用除root之外的logger,则该日志记录器的日志级别将覆盖root日志级别。要获得所需的输出,请将另外两个日志级别更改为ERROR。

我希望这会有所帮助。