关于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>
希望能对您有帮助.