Docker容器内的springCloud应用日志时间和本地时间不一致

首先要确定的是,我们在日常开发中,使用的都是东八区的时间。

在将应用部署到docker容器内时,发现docker容器内的应用日志时间和实际时间相差8小时,导致考勤定时计算的时间本应在晚上0点,却延迟到了实际早上8点。

网上找了很多方法,就不赘述了。下面是解决方法和一些思考。

在启动类增加

TimeZone.setDefault(TimeZone.getTimeZone("Asia/Shanghai"));

然后发现Date、LocalDateTime是正常的,DateTime以及应用自身的输出日志依旧是UTC时间。

在Dockerfile的java启动参数中 增加

"-Duser.timezone=GMT+8"

发现所有日志的输出时间,以及获取时间都正常了。

------------------------------------------------------------------------------

可能默认需要设置一个时区,不然就使用默认的UTC时间了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章