最近项目切换到docker管理,数据库查询也改成进docker容器访问mysql。使用时先是发现中文乱码,这个首先想到就是常见的mysql设置编码问题。临时处理的话先是应急的
set nams utf8 ;
这样查询就暂时ok了的。
上面只是应急,因为每次访问都需要set一次。根治的话还是得改mysql的my.cnf了。对应docker里的位置就是/etc/mysql/my.cnf

(这里可能得装个vim了,基础镜像不能vi,apt-get安装就行)
操作完重连mysql,执行show variables like ‘%char%’;一把
就可以看到表面UTF-8了。
上面都是常规操作了,发现还是键入中文,无论是在mysql终端,还是容器内终端都不能输入中文,这个时候初步判断是镜像的locale问题了。
剩下就是解决locale的问题了。也很简单,只需要启动或者进入容器的时候添加个参数env LANG=C.UTF-8即可。
如:
docker run -i -t mysql env LANG=C.UTF-8 /bin/bash
如果是k8s的话也是同理可得:
//启动
kubectl run -it –rm –image=mysql mysql-client – env LANG=C.UTF-8 /bin/bash
//进入pod
kubectl exec -ti mysql-client – env LANG=C.UTF-8 /bin/bash
这个时候再到容器内locale就能看到编码为utf-8的了。输入中文的问题也就解决了。