docker乱码时区异常排查解决

容器运行时 

可以使用docker exec -it 容器Id或者名称 locale     该命令查看当前语言环境
可以使用dcoker exec -it 容器Id或者名称 date    该命令查看时区和当前时间  
当然也可以使用docker exec -it 容器Id或者名称 bash   进入容器内部查看当前时间(date命令)和系统语言环境(locale)

docker 服务启动的日志(排查问题时需要)

系统    日志位置
Ubuntu(14.04)    /var/log/upstart/docker.log
Ubuntu(16.04)    journalctl -u docker.service
CentOS 7/RHEL 7/Fedora    journalctl -u docker.service
CoreOS    journalctl -u docker.service
OpenSuSE    journalctl -u docker.service
OSX    ~/Library/Containers/com.docker.docker/Data/com.docker.driver.amd64-linux/log/d‌​ocker.log
Debian GNU/Linux 7    /var/log/daemon.log
Debian GNU/Linux 8    journalctl -u docker.service
Boot2Docker    /var/log/docker.log

 

docker 容器中文乱码和时区异常问题


在Dockerfile中可以设置语言环境  和  设置时区时间等  具体如下

解决中文乱码
编辑Dockerfile 添加
ENV LANG=en_US.UTF-8  
ENV LANGUAGE=en_US:en  
ENV LC_ALL=en_US.UTF-8 
用docker部署了一个tomcat应用,并以tomcat用户运行,日志输出遇到中文就显示 ? 
dockerfile中已经明确指定了语言的环境变量ENV LC_ALL zh_CN.utf8
进入容器中执行命令locale 环境变量也是zh_CN.utf8,但是切换到tomcat用户发现LANG="POSIX"
在dockerfile中加入 RUN echo "export LANG=zh_CN.utf8" >> /home/tomcat/.bash_profile


解决时区异常问题

宿主机时间
[root@slave-1 ~]# date
Fri May 12 11:20:30 CST 2017
 
容器时间
[root@slave-1 ~]# docker exec -ti 87986863838b /bin/bash
root@87986863838b:/# date                                                                                                                    
Fri May 12 03:20:33 UTC 2017
 
发现两者之间的时间相差了八个小时!
宿主机采用了CST时区,CST应该是指(China Shanghai Time,东八区时间)
容器采用了UTC时区,UTC应该是指(Coordinated Universal Time,标准时间)
 
统一两者的时区有下面几种方法
1)共享主机的localtime
创建容器的时候指定启动参数,挂载localtime文件到容器内,保证两者所采用的时区是一致的。
# docker run -ti -d --name my-nginx -v /etc/localtime:/etc/localtime:ro  docker.io/nginx  /bin/bash
 
2)复制主机的localtime
[root@slave-1 ~]# docker cp /etc/localtime 87986863838b:/etc/
 
然后再登陆容器,查看时间,发现已经跟宿主机时间同步了
[root@slave-1 ~]# docker exec -ti 87986863838b /bin/bash
root@87986863838b:/# date                                                                                                                    
Fri May 12 11:26:19 CST 2017
 
3)创建dockerfile文件的时候,自定义该镜像的时间格式及时区。在dockerfile文件里添加下面内容:
......
FROM tomcat
ENV CATALINA_HOME /usr/local/tomcat
.......
#设置时区  Ubuntu系统
RUN /bin/ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
#centos系统
RUN /bin/ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
......
 
保存后,利用docker build命令生成镜像使用即可,使用dockerfile创建的镜像的容器改变了容器的时区,这样不仅保证了容器时间与宿主机时间一致(假如宿主机也是CST),并且像上面使用tomcat作为父镜像的话,JVM的时区也是CST,这样tomcat的日志信息的时间也是和宿主机一致的,像上面那两种方式只是保证了宿主机时间与容器时间一致,JVM的时区并没有改变,tomcat日志的打印时间依旧是UTC。

你可能感兴趣的:(docker使用)