在使用了Docker以后,因为宿主机设置了时区,而Docker容器并且设置,而遇到的一个问题就是Docker容器的时间和宿主机时间不同步,导致两者相差8小时。
接下来,我们通过在在宿主机和容器里分别执行date命令来看下实际的情况。
在宿主机执行date命令的结果:
进入到容器里,再执行date命令的结果:
综上两者时间刚好相差8小时
- 创建容器的时候指定启动参数,自动挂载localtime文件到容器内
docker run --name <name> -v /etc/localtime:/etc/localtime:ro ....
docker run -it -v /etc/timezone:/etc/timezone -v /etc/localtime:/etc/localtime 127.0.0.1:5000/project-mall:vtest
- 把时区设置加入到Dockerfile中
之后重新打包制作镜像后我们分别执行后时间则一致
当查询到容器打印日志时间与容器时间不一致时,做以下操作
FROM java:8
VOLUME /app
COPY mall-task*.jar mall-task.jar
RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
RUN echo 'Asia/Shanghai' >/etc/timezone
RUN bash -c "touch /mall-task.jar"
EXPOSE 8090
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./uranedom","-jar","-Dspring.profiles.active=pre-prod", "-Duser.timezone=GMT+08", "/mall-task.jar"]