Docker 中时区和宿主机相隔八个小时的解决方案之一
Docker 中时区和宿主机相隔八个小时的解决方案之一前言
项目部署在 tomcat 容器中,但是定时任务在凌晨插入数据到数据库后,第二天查看数据时间不对,时间延后的8个小时,于是踏上了解决之路。
关键字:Linux、Docker、Tomcat
一、问题重现
项目中设置的定时任务是凌晨0点整执行,但是第二天查看数据库发现插入的时间是当天的8点钟(为什么是延后后面会讲),然后查看日志发现,打印日志的时间也和现在对不上(比现在少八个小时),就已经很明了了,时区的问题,然后重要的是怎么解决,把这个打印时间变成和现在对应的时间。
# docker logs -f --tail 100 965abb1fb546 # 查看 docker 容器日志的最后100行,动态的(新增继续打印)
# 打的日志上面的信息会比当前的时间(北京时间)少8个小时
28-May-2020 02:41:31.492 INFO org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["http-nio-8080"]
28-May-2020 02:41:31.496 INFO org.apache.coyote.AbstractProtocol.stop Stopping ProtocolHandler ["ajp-nio-8009"]
28-May-2020 02:41:31.498 INFO org.apache.coyote.AbstractProtocol.destroy Destroying ProtocolHandler ["http-nio-8080"]
# docker exec 965abb1fb546 date # 查看指定容器的时区,965abb1fb546为容器 id
Thu May 28 02:50:42 UTC 2020
# date # 查看 linux 的时间
Thu May 28 14:19:38 CST 2020
#
1
2
3
4
5
6
7
8
9
明显一个是 UTC,一个是 CST,不一样的时区,相差八个小时。
二、分析问题
刚遇到的时候只知道是时区问题,最先想到的就是 tomcat 的时区设置不对,然后找了资料修改之后,发现并没有什么暖用,然后查资料的时候发现 docker 的时间也会出现这种情况,就把问题方向占时确认为 docker 问题(后面修改成功也证明了确实是 docker 的问题)。
三、修改 docker 容器的时区
1、进入需要修改时区的 docker 容器
# docker exec -it 965abb1fb546 /bin/bash
root@965abb1fb546:/usr/local/tomcat# cd /usr/share/zoneinfo/Asia # 进入亚洲时区文件夹
1
2、复制上海(Shanghai)时区到 localtime
root@965abb1fb546:/usr/share/zoneinfo/Asia# cp Shanghai /etc/localtime # cp 直接复制
root@965abb1fb546:/usr/share/zoneinfo/Asia# exit # 退出容器
exit
# docker restart 965abb1fb546 # 重启容器
965abb1fb546
# docker exec 965abb1fb546 date # 再次查看,已经和现在的时间对应了,时区也变成了 CST 了
Thu May 28 11:12:12 CST 2020
1
2
3
4
5
6
四、验证(重启容器并查看日志)
# docker logs -f --tail 100 965abb1fb546
28-May-2020 11:16:56.191 INFO org.apache.catalina.startup.VersionLoggerListener.log OS Name: Linux
28-May-2020 11:16:56.191 INFO org.apache.catalina.startup.VersionLoggerListener.log OS Version: 3.10.0-862.14.4.el7.x86_64
28-May-2020 11:16:56.191 INFO org.apache.catalina.startup.VersionLoggerListener.log Architecture: amd64
1
2
3
可以看到打印的日志已经和当前时间相同了。
五、说明
为什么时区时间是少了8个小时,但是数据库的时间却比设置的时间多了8个小时?
是因为数据库设置了操作时间为上海时间(Shanghai),所以插入的时候会自动在当前时间➕8个小时,指定的0点本来是指定的上海时间的0点,但是时区不对(执行的时候始终是0点),就是在另一个时区的零点执行的,另一个时区的零点其实就是 Shanghai 时间的八点中,所以数据库的时间是 Shanghai 时间的8点钟执行的,说白了就是时区把0点延后了8小时,但是保存到数据库是 Shanghai 时间,于是就➕了八个小时,有点小饶,但是想清楚了就完全能理解了。
六、参考
参考文章
总结
时区问题经常遇到,修改的地方也不尽相同,所以记录在此,下次遇到了能快速解决问题;这也只是其中一种修改 docker 容器的时区方法,还有其它的比如,启动的时候挂载宿主机的时区等,这里不再说明,网上也有很多资料,以后有遇到再记录。
————————————————
版权声明:本文为CSDN博主「忧郁的白衬衫丶」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_42816285/article/details/106403093
发表回复谢谢啦
页:
[1]