Docker容器内的springCloud应用日志时间和本地时间不一致
程序员文章站
2024-03-11 19:56:25
...
首先要确定的是,我们在日常开发中,使用的都是东八区的时间。
在将应用部署到docker容器内时,发现docker容器内的应用日志时间和实际时间相差8小时,导致考勤定时计算的时间本应在晚上0点,却延迟到了实际早上8点。
网上找了很多方法,就不赘述了。下面是解决方法和一些思考。
在启动类增加
TimeZone.setDefault(TimeZone.getTimeZone("Asia/Shanghai"));
然后发现Date、LocalDateTime是正常的,DateTime以及应用自身的输出日志依旧是UTC时间。
在Dockerfile的java启动参数中 增加
"-Duser.timezone=GMT+8"
发现所有日志的输出时间,以及获取时间都正常了。
------------------------------------------------------------------------------
可能默认需要设置一个时区,不然就使用默认的UTC时间了。
上一篇: 虚拟机docker中的MySQL数据库在宿主机上连接不上
下一篇: 第五节--决策树