11

我正在将 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 启动期间早些时候处理过)但这并没有解决问题,所以我保留了建议的文件名。

4

2 回答 2

3

我遇到类似的问题,在应用程序启动时可能会生成以下空文件:

  • LOG_PATH_IS_UNDEFINED
  • LOG_FILE_IS_UNDEFINED

原因

登录相关配置application.yml,解析后读取logback-spring.xml,无法读取。


可能的解决方案

我找到了 3 种可能的解决方案,请选择最适合您情况的一种:

  1. 将日志配置从application.yml移至bootstrap.yml,这将需要spring-cloud依赖才能使其工作。

    • 这是有效的,因为bootstrap.yml之前已阅读logback-spring.xml
    • 如果您不使用spring-cloud,这可能不是您的最佳选择,因为额外的依赖项是不必要的。
  2. 直接定义路径和文件logback-spring.xml
    例如

     <configuration>
         <springProperty name="LOG_PATH" source="logging.path" defaultValue="logs/" />
         <springProperty name="LOG_FILE" source="logging.file" defaultValue="app.log" />
    

    在这种情况下,可能需要在每个子项目中添加“logback-spring.xml”,如果日志文件名需要不同,并且不能简单地将配置文件放在共享的公共依赖中。

  3. 只需保留配置application.yml,并通过设置忽略生成的空文件.gitinore
    例如

     LOG_*_IS_UNDEFINED
    

    在这种情况下,日志仍会写入 指定的文件application.yml,但会生成空文件。


提示

  • 上面提到的logback-spring.xml文件可能是logback.xml您的情况或其他名称。
于 2020-07-11T07:55:15.300 回答
0

删除:

<include resource="org/springframework/boot/logging/logback/defaults.xml"/>
<include resource="org/springframework/boot/logging/logback/file-appender.xml"/>

来自 logback.xml 为我解决了这个问题。

于 2022-02-22T21:01:52.530 回答