今天登錄一臺很久沒有登錄的服務器執行一條 SQL,發現輸入中文全部變成亂碼了。
服務器的版本是 Ubuntu 16.04,之前借給朋友裝過 Confluence 之類的軟件測試,不知道是不是跟這個問題有關。
不管,先執行以下命令:
export LANG='zh_CN.UTF-8'
export LC_ALL='zh_CN.UTF-8'
執行後還是不行。網上搜了搜,找到這篇文章:解決ubunut系統locale: Cannot set LC_CTYPE to default locale: No such file or directory,看起來不錯,最終確實解決了我的問題。
解決過程
mkdir -p /var/lib/locales/supported.d/
cp /usr/share/i18n/SUPPORTED /var/lib/locales/supported.d/local
cd /var/lib/locales/supported.d/
cat local |grep "en_US.UTF-8 UTF-8" > 1.txt
cat local |grep "zh_CN.UTF-8 UTF-8" >> 1.txt
rm -rf local && mv 1.txt local
locale-gen --purge
locale
這時候應該就好了,不過還是要先檢查一下 locale
命令的輸出。
如果執行發現 LC_ALL
的值還是有問題(我這裏爲空),則執行:
export LC_ALL=zh_CN.UTF-8
至此,問題解決。
注意
這樣的方式其實是讓系統的語言變成中文。而之前默認是英文的,且中文也沒有亂碼,更優的方案需要進一步研究。
原文地址: CroWall Notes