欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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时间了。

相关标签: 异常处理