log4j 为什么根日志程序不管配置如何都收集所有日志类型?

3zwtqj6y  于 2022-11-06  发布在  其他
关注(0)|答案(6)|浏览(155)

我遇到的问题是,即使我在根标记中将级别指定为ERROR,指定的附加程序仍会将所有级别(调试、信息、警告)记录到文件中,而不考虑设置。我不是Log4jMaven,因此非常感谢您的帮助。
我已经检查了www.example.com的类路径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>

如果我用另一个记录器替换根目录,那么指定的附加器将不会记录任何内容。

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

r6hnlfcb1#

根日志程序位于日志程序层次结构的顶部。它在以下三个方面是例外的:

  • 它总是存在的,
  • 不能将其级别设置为空
  • 则无法按名称检索。
    rootLogger是所有附加程序的父级。给定记录程序的每个启用的事件记录请求都将转发到该记录程序中的所有附加程序以及层次结构中更高级别的附加程序(包括rootLogger)

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

  • 来自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

希望这对你有帮助。

pinkon5k

pinkon5k2#

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

ttygqcqt

ttygqcqt3#

补充一下James A. N. Stauffer和cynicalman所说的话--我敢打赌,log4j.properties在您的类路径上,除了您希望使用的那个log4j之外,还有另一个log4j.xml /www. example. com,它导致log4j按照现在的方式配置自己。
-Dlog4j.debug是解决任何log4j问题的绝对有效的方法。

jjhzyzn0

jjhzyzn04#

两件事:检查可加性,并决定是否要将更详细的日志记录级别捕获的日志事件传播到根日志记录器。
其次,检查根记录器的级别。另外,你也可以在附加器本身上添加过滤,但这通常是不必要的。

yv5phkfx

yv5phkfx5#

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

zmeyuzjn

zmeyuzjn6#

这是正确的行为。根日志记录器就像默认的行为一样。所以如果你不指定任何日志记录器,它会把根日志记录器级别作为默认级别,但这并不意味着根日志记录器级别是你所有日志的级别。
使用'TraceLogger'记录器或'org.springframework.ws.server.endpoint.interceptor'记录器记录的任何代码将分别使用TRACE和DEBUG级别记录消息。任何其他代码将使用根记录器使用级别记录消息,在您的示例中为ERROR。
所以如果你使用的日志记录器不是root,root的日志级别会被那个日志记录器的日志级别覆盖。要得到想要的输出,把另外两个日志级别改为ERROR。
我希望这是有帮助的。

相关问题