如何仅在log4j中记录警告

时间:2014-09-26 05:26:05

标签: java properties log4j warnings

在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");
    }
}

任何帮助将不胜感激!

1 个答案:

答案 0 :(得分:3)

使用org.apache.log4j.varia.LevelRangeFilter过滤器。您的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

看起来属性文件配置不支持过滤器。以下内容来自log4j的官方维基:

  

PropertiesConfigurator不支持过滤。

编辑:添加了控制台appender以及XML并关闭了log4j的调试。现在它应该转到文件和控制台。