docker k8s mysql 命令行 sql 不能输入中文

目录

目标

在 docker 容器中,通过 mysql -u name -p 的方式登录命令行终端后,可能会出现,在执行 sql 语句时,可能会出现无法输入中文字符的情况。

现象

sql 复制代码
update table_name set column_name = 'abc_姓名' where id = '1';

结果在终端只能输入为

sql 复制代码
update table_name set column_name = 'abc_' where id = '1';

原因

进入 deocker 容器,查询 locale ,可以看到系统使用的是POSIX字符集。

POSIX字符集是不支持中文的,而C.UTF-8是支持中文的,只要把系统中的环境 LANG 改为"C.UTF-8"格式即可解决问题。

shell 复制代码
root@yh:~# docker exec -it yh-mysql bash
root@5edc6da46079:/# 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"
LC_ALL=

解决

通过 env LANG=C.UTF-8 参数登入 docker 容器

shell 复制代码
root@yh:~# docker exec -it yh-mysql env LANG=C.UTF-8 /bin/bash
root@5edc6da46079:/# locale
LANG=C.UTF-8
LANGUAGE=
LC_CTYPE="C.UTF-8"
LC_NUMERIC="C.UTF-8"
LC_TIME="C.UTF-8"
LC_COLLATE="C.UTF-8"
LC_MONETARY="C.UTF-8"
LC_MESSAGES="C.UTF-8"
LC_PAPER="C.UTF-8"
LC_NAME="C.UTF-8"
LC_ADDRESS="C.UTF-8"
LC_TELEPHONE="C.UTF-8"
LC_MEASUREMENT="C.UTF-8"
LC_IDENTIFICATION="C.UTF-8"
LC_ALL=

此时,正常登录 mysql后,执行含有中文的 sql 即可。

注意 :这样修改只是临时修改。要永久修改,需要在创建容器时在dockerfile中设置。

K8s进入pod不能输入中文 也可用此方法解决。

相关推荐
小韩博26 分钟前
metasploit 框架安装更新遇到无法下载问题如何解决
linux·网络安全·公钥·下载失败
长臂人猿30 分钟前
JVM常用工具:jstat、jmap、jstack
linux·运维·jvm
苏婳66630 分钟前
【最新版】怎么下载mysqlclient并成功安装?
数据库·python·mysql
轻松Ai享生活1 小时前
揭秘 linux:一张图看懂系统配置的核心
linux
wdxylb1 小时前
云原生俱乐部-RH134知识点总结(2)
linux·云原生
_Chipen1 小时前
lazy_vim_cmake_clangd_从零到自动补全与语法检查
linux·编辑器·vim
deeper_wind2 小时前
k8s-单主机Master集群部署+单个pod部署lnmp论坛服务(小白的“升级打怪”成长之路)
云原生·容器·kubernetes
椰子今天很可爱2 小时前
静态库和动态库
linux
檀越剑指大厂2 小时前
【Linux系列】如何在 Linux 服务器上快速获取公网
linux·服务器·php
共享家95273 小时前
linux-高级IO(上)
java·linux·服务器