原文 https://cloud.tencent.com/developer/article/1642346
问题背景:
编辑 /etc/locale.conf 改成 LANG="en_US.UTF-8" , 重启服务器后,进入系统,仍然是显示中文
排查分析:(复现问题环境)
- 确认当前系统支持 en_US.UTF-8 语言环境(en_US.utf8 和 en_US.UTF-8 两种写法效果一致)
# locale -a | grep en_US en_US en_US.iso88591 en_US.iso885915 en_US.utf8 //英文utf8语言环境是支持的
- 确认当前系统生效的语言环境
root@BJ-CentOS7 ~ # echo $LANG zh_CN.UTF-8 //生效中的语言环境是中文utf8 root@BJ-CentOS7 ~ # locale LANG=zh_CN.UTF-8 //生效中的语言环境是中文utf8 LC_CTYPE="zh_CN.UTF-8" LC_NUMERIC="zh_CN.UTF-8" LC_TIME="zh_CN.UTF-8" LC_COLLATE="zh_CN.UTF-8" LC_MONETARY="zh_CN.UTF-8" LC_MESSAGES="zh_CN.UTF-8" LC_PAPER="zh_CN.UTF-8" LC_NAME="zh_CN.UTF-8" LC_ADDRESS="zh_CN.UTF-8" LC_TELEPHONE="zh_CN.UTF-8" LC_MEASUREMENT="zh_CN.UTF-8" LC_IDENTIFICATION="zh_CN.UTF-8" LC_ALL=
- 查看系统中当前配置,确实配置的是英文,并且已经重启过服务器,环境变量$LANG的配置应该生效才对,其他相关配置文件中也没发现相关配置
root@BJ-CentOS7 ~ # grep LANG /etc/locale.conf LANG="en_US.UTF-8" root@BJ-CentOS7 ~ # grep LANG /etc/profile root@BJ-CentOS7 ~ # grep LANG ~/.bashrc
- 发现VNC下正常生效,远程连接不生效 问题基本清楚了,远程连接时SSH的配置传递了当前环境变量配置到远程主机会话中 ssh配置文件参考简介:https://www.cnblogs.com/52linux/archive/2012/03/24/2415470.html
原来是作为跳板的服务器和要连接的目标服务器中默认配置了 SendEnv 和 AcceptEnv 参数,且客户端和远程主机中都配置了 $LANG 变量,这导致客户端环境中指定的环境变量在远程会话中生效了
客户端 ssh_config 配置文件中:SendEnv 参数用来定义发送哪些环境变量到远程会话中 远程主机 sshd_config 配置文件中:AcceptEnv 参数用来定义接收哪些匹配到的环境变量
root@BJ-CentOS7 ~ # grep AcceptEnv /etc/ssh/sshd_config AcceptEnv LANG LC_CTYPE LC_NUMERIC LC_TIME LC_COLLATE LC_MONETARY LC_MESSAGES AcceptEnv LC_PAPER LC_NAME LC_ADDRESS LC_TELEPHONE LC_MEASUREMENT AcceptEnv LC_IDENTIFICATION LC_ALL LANGUAGE AcceptEnv XMODIFIERS root@BJ-CentOS7 ~ # root@BJ-CentOS7 ~ # grep SendEnv /etc/ssh/ssh_config SendEnv LANG LC_CTYPE LC_NUMERIC LC_TIME LC_COLLATE LC_MONETARY LC_MESSAGES SendEnv LC_PAPER LC_NAME LC_ADDRESS LC_TELEPHONE LC_MEASUREMENT SendEnv LC_IDENTIFICATION LC_ALL LANGUAGE SendEnv XMODIFIERS
解决方案:
- 直接通过远程工具连接服务器,将不受客户端 ssh 配置影响
- 在客户端或远程主机SSH配置中去掉$LANG变量传递的相关配置 ssh_config 和 sshd_config 配合文件中分别去掉 SendEnv 和 AcceptEnv 参数后的 LANG 值