我正在将 SpringBoot 与 LogBack 一起使用,并且我试图将一个特定包(此处显示为“com.example.somepackagename”)的所有日志语句定向到一个文件。所有其他日志语句应转到标准输出。
起初遇到的问题是在启动期间创建了一个文件“LOG_FILE_IS_UNDEFINED”。然后我用谷歌搜索了这个问题(在 github 上找到了这个,或者在 StackOverflow和其他几个上找到了这个),但没有一个附件真正解决了这个问题。
基于杂项。我使用 logback-spring.xml 文件提出了以下配置:
<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<property name="LOG_PATH" value="${LOG_PATH:-${LOG_TEMP:-${java.io.tmpdir:-/tmp}}}" />
<property name="LOG_FILE" value="${LOG_FILE:-ts-msgs.log}" />
<include resource="org/springframework/boot/logging/logback/defaults.xml" />
<include resource="org/springframework/boot/logging/logback/file-appender.xml" />
<appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<Pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{36} - %msg%n</Pattern>
</encoder>
</appender>
<appender name="MSG_LOG_FILE" class="ch.qos.logback.core.rolling.RollingFileAppender">
<file>${LOG_PATH}/${LOG_FILE}</file>
<encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
<Pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} ${LOG_LEVEL_PATTERN:-%5p} ${PID:- } --- [%t] %-40.40logger{39} : %m%n%wex</Pattern>
</encoder>
<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
<!-- rollover daily -->
<fileNamePattern>${LOG_PATH}/archived/debug.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
<timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
<maxFileSize>10MB</maxFileSize>
</timeBasedFileNamingAndTriggeringPolicy>
</rollingPolicy>
</appender>
<logger name="com.example.somepackagename" additivity="false" level="debug">
<appender-ref ref="MSG_LOG_FILE" />
</logger>
<logger name="org.springframework" additivity="false" level="info">
<appender-ref ref="STDOUT" />
</logger>
<root level="warn">
<appender-ref ref="STDOUT" />
</root>
</configuration>
有了这个,我不再得到一个名为“LOG_FILE_IS_UNDEFINED”的文件,但 LogBack 现在总是首先在应用程序的工作目录中创建一个空文件“ts-msgs.log”,然后再在临时文件中创建一个同名的文件-目录(该文件应该放在哪里)。因此,不知何故,在初始化期间它已经创建了一个具有正确名称但尚未设置正确路径的文件。换句话说,SpringBoot 中 Logback 的初始化顺序似乎被破坏了(或者至少不直观),并且似乎不可能避免在定义和应用文件附加器的正确路径之前创建第一个日志文件。
如何防止创建第一个、初始和空的日志文件?这是必要的,因为工作目录通常是写保护的,并且尝试在那里创建文件会导致异常(通常是程序被终止)。
有什么提示或建议吗?
顺便说一句:我已经尝试将该文件重命名为 logback.xml (这似乎在 SpringBoot 启动期间早些时候处理过)但这并没有解决问题,所以我保留了建议的文件名。