在 Struts 2 应用程序中,我们使用 log4j 进行日志记录。我只想记录警告,但是当我尝试在 log4j.properties 中使用时
log4j.rootLogger=warn, stdout
它也打印错误和致命日志。我只想要警告日志。我在一些教程中阅读了日志级别。所以我知道为什么错误和致命打印,因为它们的优先级低于警告。如何仅在我的控制台中打印警告日志?
我的Java代码:
import org.apache.log4j.Logger;
public class LogClass {
private static final org.apache.log4j.Logger log = Logger.getLogger(LogClass.class);
public static void main(String[] args) {
log.trace("Trace");
log.debug("Debug");
log.info("Info");
log.warn("Warn");
log.error("Error");
log.fatal("Fatal");
}
}
任何帮助将不胜感激!
Use the org.apache.log4j.varia.LevelRangeFilter https://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/varia/LevelRangeFilter.html筛选。您的 XML 配置文件可能是:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE log4j:configuration SYSTEM "log4j.dtd">
<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/"
debug="false">
<appender name="warn-out" class="org.apache.log4j.FileAppender">
<param name="File" value="warn.log" />
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%m%n" />
</layout>
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<param name="LevelMax" value="warn" />
<param name="LevelMin" value="warn" />
<param name="AcceptOnMatch" value="true" />
</filter>
</appender>
<appender name="console" class="org.apache.log4j.ConsoleAppender">
<layout class="org.apache.log4j.PatternLayout">
<param name="ConversionPattern" value="%m%n" />
</layout>
<filter class="org.apache.log4j.varia.LevelRangeFilter">
<param name="LevelMax" value="warn" />
<param name="LevelMin" value="warn" />
<param name="AcceptOnMatch" value="true" />
</filter>
</appender>
<root>
<level value="warn" />
<appender-ref ref="warn-out" />
<appender-ref ref="console" />
</root>
</log4j:configuration>
如需更多选择,请前往here http://wiki.apache.org/logging-log4j/LogToAppenderByLevel.
看起来属性文件配置不支持过滤器。以下内容摘自log4j的官方wiki:
过滤器不支持PropertiesConfigurator http://logging.apache.org/log4j/1.2/apidocs/org/apache/log4j/PropertyConfigurator.html.
EDIT:向 XML 中添加了控制台附加程序,并关闭了 log4j 的调试。现在它应该转到文件和控制台。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)