log4j 2中不同级别的日志未显示正确的日志

时间:2016-08-11 02:20:00

标签: logging log4j2 log-level

在此先感谢,我创建了log4j 2 XML文件,创建了3种类型的日志文件 - info,debug,error。 我的XML看起来像这样:

<?xml version="1.0" encoding="UTF-8"?>
<Configuration monitorInterval="30" status="DEBUG">
    <Appenders>
        <File name="errorFile" fileName="D:/logger/error.log"   append="false">
            <PatternLayout pattern="%d{yyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
        </File>
        <File name="debugFile" fileName="D:/logger/debug.log"  append="false">
            <PatternLayout pattern="%d{yyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
        </File>
        <File name="infoFile" fileName="D:/logger/info.log"  append="false">
            <PatternLayout pattern="%d{yyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/>
        </File>
    </Appenders>
    <Loggers>
        <logger name="com.vt.logger" level="info" additivity="false">
            <AppenderRef ref="errorFile" level="ERROR"/>
            <AppenderRef ref="debugFile" level="DEBUG"/>
            <AppenderRef ref="infoFile" level="INFO"/>
        </logger>
    </Loggers>
</Configuration>

和我的主要计划:

public class LoggerLevelTest {
    private final static Logger log = LogManager.getLogger(LoggerLevelTest.class);

    public static void main(String[] args) {
        log.info("This is info log");
        log.debug("This is debug log");
        log.error("This is error log");
    }
}

我的问题: 该程序将创建3个单独的文件,其中error.log仅包含ERROR级别日志,但debug.log和info.log将包含ERROR和INFO级别日志。

为什么我在debug.log和info.log文件中获取ERROR和INFO日志?

0 个答案:

没有答案