我遇到的问题是,即使我在根标记中将级别指定为 ERROR,指定的附加程序也会将所有级别(调试、信息、警告)记录到文件中,而不管设置如何。我不是 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>
如果我用另一个记录器替换根,那么指定的附加程序根本不会记录任何内容。
<logger name="com.mydomain.logic">
<level value="error" />
<appender-ref ref="errorLog" />
</logger>
最佳答案
根记录器位于记录器层次结构的顶部。它在三个方面与众不同:
- 它永远存在,
- 其级别不能设置为空
- 无法按名称检索。
rootLogger 是所有 appender 的父亲。给定 logger 的每个启用的日志记录请求都将转发到该 logger 中的所有 appender 以及层次结构中更高的 appender(包括 rootLogger)
例如,如果将 console
附加程序添加到 root logger
,则所有启用的日志记录请求将至少打印在控制台上.如果另外一个文件追加器被添加到一个记录器,比如 L
,那么启用的 L
和 L's
子级的记录请求将打印在一个文件上控制台
上的和。 通过将可加性标志设置为 false,可以覆盖此默认行为,以便 appender 累积不再是加法的。
来自 log4j 手册
总结一下:
如果您不想将日志记录事件传播到父记录器(例如 rootLogger),则在这些记录器中添加可加性标志为 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
希望这会有所帮助。
关于java - 为什么无论配置如何,根记录器都会收集所有日志类型?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/86878/