使用docker-compose部署时,在输出的日志以及相关事件校验及输出时,导致事件与现实相差8小时。
排查问题:
1.查看宿主机时间:
?
1
2
3
4
5
6
# 查看时间
date
Wed Sep 29 11:12:44 CST 2021
# 查看时区
date -R
Wed, 29 Sep 2021 11:13:34 +0800
2.进入容器查看时间
?
1
2
3
4
5
6
# 查看所有容器
docker ps -a
# 进入容器
docker eec -it [容器ID] /bin/bash
# 查看时间
date
此时看到的宿主机时间与docker容器的时间一样,此时各种百度,终于知道是timezone的问题
linux时间:
容器时间:
原因:宿主机设置了时区,而Docker容器并没有设置,导致两者相差8小时
CST应该是指(China Shanghai Time,东八区时间)
UTC应该是指(Coordinated Universal Time,标准时间)
所以,这2个时间实际上应该相差8个小时
所以,必须统一两者的时区
解决方案:
1.docker-compose配置卷挂载
?
1
2
volumes:
– /usr/share/zoneinfo/Asia/Shanghai:/etc/localtime
2.Dockerfile运行命令以及输出对应时区到timezone中
?
1
2
3
RUN echo “Asia/shanghai” > /etc/timezone
RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
3.删除容器,并重新运行
?
1
2
3
4
#删除
docker rm [容器ID]
# 启动
docker-compose -f [文件名] up -d
总结:导致时差查2小时是容器中的/etc/timezone的问题,对此进行设置相应的时区即可。
到此这篇关于docker容器与宿主机相差8小时的文章就介绍到这了,更多相关docker容器与宿主机内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/syslbjjly/article/details/101516746
声明: 猿站网有关资源均来自网络搜集与网友提供,任何涉及商业盈利目的的均不得使用,否则产生的一切后果将由您自己承担! 本平台资源仅供个人学习交流、测试使用 所有内容请在下载后24小时内删除,制止非法恶意传播,不对任何下载或转载者造成的危害负任何法律责任!也请大家支持、购置正版! 。本站一律禁止以任何方式发布或转载任何违法的相关信息访客发现请向站长举报,会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。本网站的资源部分来源于网络,如有侵权烦请发送邮件至:2697268773@qq.com进行处理。