日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

nxlog 中文乱码解决

發布時間:2023/12/31 编程问答 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 nxlog 中文乱码解决 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

nxlog 中文亂碼解決

本篇文章主要介紹使用nxlog作為日志推送工具時,遇到的中文亂碼問題

背景

項目基于springboot開發,使用log4j日志插件,用tomcat作為運行容器,運行在windows環境下。日志都輸出到tomcat的\apache-tomcat-8.0.53\logs\catalina.out文件中。因為想在linux環境下的graylog應用中也能收到Windows環境下項目產生的日志,所以使用nxlog作為日志推送工具,但是推送到graylog端的日志中包含的中文都是亂碼,如下圖所示:

原有nxlog配置

nxlog配置文件路徑:C:\Program Files (x86)\nxlog\conf\nxlog.conf

## 主要配置項<Extension _syslog>Module xm_syslog </Extension><Input testfile>Module im_fileFile "D:\apache-tomcat-8.0.53\logs\catalina.*.out" SavePos TRUE </Input><Output out>Module om_tcpHost 192.168.1.101Port 514 </Output><Route 1>Path testfile => out </Route>

原因分析

通過查找網上資料,綜合其他人遇到的情況判斷,應該是由于項目默認編碼為UTF-8,但是window系統默認編碼為GBK,編碼不一致導致輸出的日志文件沒有以正確的編碼讀取導致發送給graylog的數據亂碼。

解決

通過在配置文件中引入nxlog的xm_charconv(字符集轉換)模塊,在讀取日志文件的時候,自動將其他的編碼類型轉換為utf-8編碼來解決亂碼問題。

更新后的nxlog配置文件

## 主要配置項<Extension _syslog>Module xm_syslog </Extension><Extension xm_charconv>Module xm_charconvAutodetectCharsets gbk, utf-8, euc-jp, utf-16, utf-32, iso8859-2 </Extension><Input testfile>Module im_fileFile "D:\apache-tomcat-8.0.53\logs\catalina.*.out" Exec convert_fields("AUTO", "utf-8");SavePos TRUE </Input><Output out>Module om_tcpHost 192.168.1.101Port 514 </Output><Route 1>Path testfile => out </Route>

結果

修改完配置文件后,重啟nxlog服務,即可看到新發送的沒有亂碼的日志了:

參考

[bug報告]nxlog字符集轉化導致內存泄漏
Nxlog配置
字符集轉換(xm_charconv)
nxlog | Logstash 最佳實踐

總結

以上是生活随笔為你收集整理的nxlog 中文乱码解决的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。