问题描述
我已经使用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
目录确实存在。