docker运行java程序时间差8个小时和中文乱码问题解决

docker运行java程序时间差8个小时问题解决

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

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

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

docker exec -it <containerid> /bin/sh
date

执行后的结果为:
ww20160419151449

从截图来看,我们发现相差了8个小时。那么如何解决这个问题呢?目前有两种思路供参考

  • 创建容器的时候指定启动参数,自动挂载localtime文件到容器内
 docker run --name <name> -v /etc/localtime:/etc/localtime:ro  .... 
  • 把时区设置加入到Dockerfile中
# CentOS

RUN echo "Asia/shanghai" > /etc/timezone;

# Ubuntu

RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime

docker 中文乱码以及时区差8小时的解决办法

    环境:主机环境CentOS 7.2.1511
         镜像为CentOS 7.2.1511。
    设置时区。
RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && \ 
    echo 'Asia/Shanghai' >/etc/timezone
    接下来解决中文乱码:
    设置环境变量:
ENV LANG="zh_CN.UTF-8" 
    设置后,运行出现Failed to set locale, defaulting to C 这样的提示后,在设置环境变量之前加上:
  •  
RUN echo "export LC_ALL=zh_CN.UTF-8"  >>  /etc/profile
  • 1
    如果依旧乱码的话,就需要安装kde-l10n-Chinese,glibc-common。安装完成后相关的问题即可解决。

以了

# CentOS

RUN echo "Asia/shanghai" > /etc/timezone;

# Ubuntu

RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime

猜你喜欢

转载自blog.csdn.net/xl_lx/article/details/81179268
今日推荐