解決CentOS7中文語言亂碼(包括Tomcat日志中文亂碼)問題


   Linux系統中文語言亂碼,是很多小伙伴在開始接觸Linux時經常遇到的問題,而且當我們將已在Wndows部署好的項目搬到Linux上運行時,Tomcat的輸出日志中文全為亂碼(在Windows上正常),看着非常心塞,那么我們應該怎么解決呢?

  

               系統中文亂碼

                Tomcat輸出日志中文亂碼

 系統環境

  • CentOS 7.0 64位
  • jdk-8u11-linux-x64.
  • apache-tomcat-8.5.16

     解決步驟:

   1.安裝中文語言包  

        先查看系統是否有安裝中文語言包  

       # locale -a  (列出所有可用的公共語言環境的名稱)

        

                     若發現以上幾項,說明系統已安裝中文語言包,無需再安裝,那這幾項代表什么意思呢?

        {語言代號}_{國家代號}.{字符集}

        zh是中文的代號、CN是中國的代號、gb18030,gb2312,utf8是語言字符集

        那么每一項可以通俗理解為   “你是說中文的,你在中國,語言字符集是gb18030/gb2312/utf8”

        如果沒有發現以上幾項,則手動安裝中文語言包

       # yum install kde-l10n-Chinese            (大概11M)

   2.修改i18n國際化和locale.conf本土化配置文件

      在修改配置文件之前,我們先看看當前系統語言環境

                        #    locale  

          

 ("en_US.UTF-8"按照上面的內容可以理解為“你說英語,你在美國,語言字符集為UTF-8”) 

            每項的意思分別為 :

       LANG:當前系統的語言

                    LC_CTYPE:語言符號及其分類

       LC_NUMERIC:數字

       LC_COLLATE:比較和排序習慣

       LC_TIME:時間顯示格式

       LC_MONETARY:貨幣單位

      LC_MESSAGES:信息主要是提示信息,錯誤信息, 狀態信息, 標題, 標簽, 按鈕和菜單等

      LC_NAME:姓名書寫方式

      LC_ADDRESS:地址書寫方式

      LC_TELEPHONE:電話號碼書寫方式

      LC_MEASUREMENT:度量衡表達方式

        LC_PAPER:默認紙張尺寸大小

        LC_IDENTIFICATION:對locale自身包含信息的概述

     LC_ALL:優先級最高變量,若設置了此變量,所有LC_* 和LANG變量會強制跟隨它的值

     我們看到雖然安裝了中文語言包但本機的語言環境並不是中文,先修改i18n配置文件

     #    vim /etc/sysconfig/i18n

      添加如下兩行代碼

      LANG="zh_CN.UTF-8"
      LC_ALL="zh_CN.UTF-8"

     

    #  source    /etc/sysconfig/i18n

    再修改 locale.cnf配置文件

    #   vim /etc/locale.conf

              LANG="zh_CN.UTF-8"

      

              #  source   /etc/locale.conf

     重啟系統

     # reboot

  3.設置終端連接編碼

     文件->打開->選中會話->右鍵->屬性->終端 (我用的終端連接工具是Xshell,其它連接工具更改編碼方式請自行百度)

     將編碼改為 UTF-8

        

     重新連接,再查看當前系統語言環境

      # locale 

                    

     發現系統語言環境已經成功改為 “zh_CN.UTF-8”

     再次嘗試編輯中文

     # vim 你是豬嗎

     

      #  ls

     

     SUCCESS!至此,系統中文亂碼問題已解決。

  4.解決Tomcat輸出日志亂碼

  既然系統中文亂碼已經解決了,那么Tomcat輸出日志中文亂碼會不會也解決了呢?

  我們現在看看Tomcat輸出日志  

  進入Tomcat目錄

      # cd $CATALINA_HOME

     #  tail -f ./logs/catalina.out

      

  很遺憾,Tomcat日志中文還是亂碼。

  分析:既然系統已經不會出現中文亂碼,證明系統語言環境是正常的,但是Tomcat日志還會出現中文亂碼,說明是Tomcat內部的問題,網上查了一些資料,知道是JVM(Java Virtual Machine)

     java虛擬機所用的字符集與系統所用的字符集不一致造成的,知道原因,問題就好解決了,可以通過配置JVM的啟動參數來達到修改JVM所使用字符集的目的。

       # ls -l ./bin/

      

  找到 daemon.sh 和 catalina.sh   分別加入以下代碼:

      JAVA_OPTS="$JAVA_OPTS -Djavax.servlet.request.encoding=UTF-8 -Dfile.encoding=UTF-8 -Duser.language=zh_CN -Dsun.jnu.encoding=UTF-8"

      # vim ./bin/daemon.sh

     

     # vim ./bin/catalina.sh

  

  保存退出,重啟Tomcat

  # ./bin/shutdown.sh

    # ./bin/startup.sh

 現在再查看輸出日志

   # tail -f ./logs/catalina.out

  向服務器發一次請求

 

 Tomcat輸出日志中文正常顯示。

           end!    (*^-^*)        

                          -----------------------------------------------本人能力有限,有錯誤或者不足之處歡迎指正,也歡迎聯系我交流學習------------------------------------------------------------

聯系方式

  • 電子郵箱:
  • 微信號:R1284103044

                                                                                           By 網維團隊-----謝崢嶸


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM