Docker容器部署项目少了8个小时,问题解决&&Dockerfile修改linux时区
情景回顾
打包好的jar包通过Dockerfile构建成一个镜像后,通过docker-compose.yml文件实现对 Docker 容器集群的快速编排,当这一切都很顺利进行时,发现在走业务的时候,产生的时间戳存放在通过Docker启动的mysql容器中,时间比当前系统时间少了8个小时; 可能原因如下:
1、时区问题
在数据库连接的url中如果设置了serverTimezone=UTC,连接时不报错,但是在产生当前系统时间戳的时候往往会少了8个小时,这是因为UTC是全球的标准时间,但是我们使用的是北京时区(东八区),会比UTC多了8个小时,可以通过DataSource.url中添加
// 北京时间
serverTimezone=GMT%2B8
// 上海时间
serverTimezone=Asia/Shanghai
但是问题在这里并没有得到解决,于是在docker容器中查询了当前系统时间,发现当前容器系统时间少了8个小时,于是我们需要去修改容器里边的系统时间
2、修改docker容器系统时间
通过这条命令去修改当前容器系统时间,然后在重启容器
ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
这是我们再次查看当前容器系统时间,发现已经是东八区的时间,这时我以为问题解决了,没想到再次测试业务时,发现问题还没有解决,而且后端系统日志的时间依旧是少了8个小时,这时要去查看jvm是如何获取系统时间
3、修改JVM获取时间的文件
通过百度百科得知,运行在容器上JVM是通过/etc/timezone去获取时区的,我们通过以下echo去重写/etc/timezone,修改为东八区
RUN echo "Asia/Shanghai" > /etc/timezone
到这里问题已经全部解决了,但是又想到,如果每次等到容器启动后去修改配置,在关闭容器,重新build容器后在启动,实在是很没必要哈哈,所以我在构建Dockerfile时就要解决这些问题,添加以下命令
RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
RUN echo "Asia/Shanghai" > /etc/timezone
以上乃个人拙见,如有不当,请多指教
|