关于logback-spring.xml日志时区相差8小时问题解决

之前使用logback-spring.xml,里面的内容,使用的是yyyy-MM-dd HH:mm:ss.SSS,我容器的基础镜像设置好的上海时区,而且还在Dockerfile里设置了对应了上海时区的环境变量,但是日志的时间还是差8小时.
后来想到是日志配置的问题,发现yyyy-MM-dd HH:mm:ss.SSS最后的SSS表示的时区,直接把SSS换成Asia/Shanghai,例如yyyy-MM-dd HH:mm:ss.Asia/Shanghai就可以了

<?xml version="1.0" encoding="UTF-8"?>
<configuration>
    <include resource="org/springframework/boot/logging/logback/defaults.xml"/>

    <!--注意时区的指定,否则即使你在容器里是正确的时区,这里的日志也是不对的SSS换成Asia/Shanghai-->
    <property name="CONSOLE_LOG_PATTERN"
              value="%clr(%d{yyyy-MM-dd HH:mm:ss.Asia/Shanghai}){faint} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}"/>
    <property name="FILE_LOG_PATTERN"
              value="%d{yyyy-MM-dd HH:mm:ss.Asia/Shanghai} ${LOG_LEVEL_PATTERN:-%5p} [%15.15t] %-40.40logger{39} : %msg%n"/>
    <!-- Appender to log to console -->
    <appender name="console" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>${CONSOLE_LOG_PATTERN}</pattern>
            <charset>utf8</charset>
        </encoder>
    </appender>

    <!-- Appender to log to file -->
    <appender name="file"
              class="ch.qos.logback.core.rolling.RollingFileAppender">
        <!--如果配置文件名不由application.xx改为bootstrap.xx的话,就会生成一个找不到LOG_FILE_IS_UNDEFINED的文件-->
        <file>${LOG_FILE}</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy">
            <fileNamePattern>${LOG_FILE}.%d{yyyy-MM-dd}.%i.log</fileNamePattern>
            <maxFileSize>50MB</maxFileSize>
            <maxHistory>60</maxHistory>
            <totalSizeCap>10GB</totalSizeCap>
        </rollingPolicy>
        <encoder>
            <pattern>${FILE_LOG_PATTERN}</pattern>
            <charset>utf8</charset>
        </encoder>
    </appender>
    
    <root level="INFO">
        <appender-ref ref="console"/>
        <appender-ref ref="file"/>
    </root>
</configuration>

希望能对您有帮助.

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐