Docker-MySQL容器内无法输入中文

dockerhub拉取MySQL镜像,启动并进入容器,发现MySQL命令行内无法输入中文 ,退出到容器终端同样无法输入中文。

容器终端查看语言环境

# locale
LANG=
LANGUAGE=
LC_CTYPE="POSIX"
LC_NUMERIC="POSIX"
LC_TIME="POSIX"
LC_COLLATE="POSIX"
LC_MONETARY="POSIX"
LC_MESSAGES="POSIX"
LC_PAPER="POSIX"
LC_NAME="POSIX"
LC_ADDRESS="POSIX"
LC_TELEPHONE="POSIX"
LC_MEASUREMENT="POSIX"
LC_IDENTIFICATION="POSIX"

容器系统内默认用POSIX字符集,而POSIX字符集不支持中文。

查看容器系统支持字符集

# locale -a
C
C.UTF-8
POSIX

C.UTF-8支持中文,把系统中语言环境 LANG 改为"C.UTF-8"格式即可解决问题。

1.临时修改

方法1.进入Mysql容器命令

docker exec -it 容器id env LANG=C.UTF-8 /bin/sh

方法2.Mysql容器内终端执行

export LANG=C.UTF-8 # 临时生效

2.持久修改-Dockerfile

要永久修改需在创建镜像时在Dockerfile中设置。

在Dockerfile中添加一行 ENV LANG C.UTF-8 ,重新制作Mysql镜像

FROM mysql:8.0

ENV LANG C.UTF-8

3.持久修改-docker-compose.yml

docker-compose.yml添加如下配置:

environment:
    TZ: "Asia/Shanghai"
    LANG: en_US.UTF-8
    volumes:
    - /etc/localtime:/etc/localtime:ro

猜你喜欢

转载自blog.csdn.net/wangshiqi666/article/details/130498331