docker容器时间与系统时间不一致

在使用了Docker以后,因为宿主机设置了时区,而Docker容器并且设置,而遇到的一个问题就是Docker容器的时间和宿主机时间不同步,导致两者相差8小时。

接下来,我们通过在在宿主机和容器里分别执行date命令来看下实际的情况。
在宿主机执行date命令的结果:

进入到容器里,再执行date命令的结果:

综上两者时间刚好相差8小时

  • 创建容器的时候指定启动参数,自动挂载localtime文件到容器内

docker run --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中

docker容器时间与系统时间不一致_第1张图片

之后重新打包制作镜像后我们分别执行后时间则一致

当查询到容器打印日志时间与容器时间不一致时,做以下操作

docker容器时间与系统时间不一致_第2张图片

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"]

你可能感兴趣的:(docker)