logback-spring.xml使用org / springframework / boot / logging / logback / base.xml记录到文件

问题描述

我已经使用Spring Boot创建了一个测试项目,以了解有关使用logback-spring.xml文件的信息。我想使用Spring的认设置写入控制台,所以我使用以下行

<include resource="org/springframework/boot/logging/logback/base.xml" />

我还想滚动记录一个文件,并在系统上保留最大数量的日志文件。写入控制台按预期工作。但是,没有日志写入日志文件。创建名为“ logs”的文件夹,并创建“ logfile.log”文件。但是没有任何记录。

下面是填充logback-spring.xml文件

<?xml version="1.0" encoding="UTF-8"?>

<configuration>
    <include resource="org/springframework/boot/logging/logback/base.xml" />
    <property name="LOG_PATH" value="logs" />
    <property name="LOG_ARCHIVE" value="${LOG_PATH}/archive" />

    <appender name="File-Appender" class="ch.qos.logback.core.FileAppender">
        <file>${LOG_PATH}/logfile.log</file>
        <encoder>
            <pattern>%d{dd-MM-yyyy HH:mm:ss.SSS} %magenta([%thread]) %highlight(%-5level) %logger{36}.%M - %msg%n</pattern>
            <outputPatternAsHeader>false</outputPatternAsHeader>
        </encoder>
    </appender>

    <logger name="test" level="DEBUG" />
</configuration>

下面是TestApplication.java文件,它是test软件包的一部分

@SpringBootApplication
public class TestApplication {

    private static final Logger logger = LoggerFactory.getLogger(TestApplication.class);

    public static void main(String[] args) {
        SpringApplication.run(TestApplication.class,args);
        logger.trace("Trace Message!");
        logger.debug("Debug Message!");
        logger.info("Info Message!");
        logger.warn("Warn Message!");
        logger.error("Error Message!");
    }

}

为什么什么都没有记录到文件中?

解决方法

我认为有几个问题。

首先,删除行<logger name="test" level="DEBUG" />。这样就为包test下的类设置了一个记录器,但未定义任何附加程序,因此未记录任何内容。

一旦消失,添加

<root level="DEBUG">
    <appender-ref ref="File-Appender"/>
</root>

这将在调试级别配置根记录器(所有记录器都继承),并将所有日志输出到File-Appender

此外,我不记得登录是否创建了丢失的目录,因此在启动应用程序之前,您可能需要确保logs目录确实存在。