Python日志转JSON格式输出到ELK时,中文乱码

前言

常规我们需要把业务日志转成JSON格式输入到ELK中。经常会碰到中文乱码的问题

解决方案
  • 方案a: pythonjsonlogger [自动把日志转化json]

    安装方式& 中文乱码解决方法

  pip install pythonjsonlogger
import logging
from pythonjsonlogger import jsonlogger
logger = logging.getLogger()
logHandler = logging.StreamHandler()
fmt="%(asctime) %(levelname) %(filename) %(funcName) %(lineno) %(message)"
datefmt="%Y-%m-%dT%H:%M:%SZ%z"
formatter = jsonlogger.JsonFormatter(fmt=fmt, datefmt=datefmt,json_ensure_ascii=False)  ### 指定参数json_ensure_ascii=False
logHandler.setFormatter(formatter)
logger.setLevel("INFO")
logger.addHandler(logHandler)
""" 
在默认情况下,对于非ascii字符生成的是相对应的字符编码,
而非原始字符,需要设置参数json_ensure_ascii=False
""" 
  • 方案b: 通过json.dumps() 自己封装
    中文乱码解决方法
items = json.dumps(test_dict, ensure_ascii=False)  ### ensure_ascii=False
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,663评论 25 708
  • 用两张图告诉你,为什么你的 App 会卡顿? - Android - 掘金 Cover 有什么料? 从这篇文章中你...
    hw1212阅读 12,993评论 2 59
  • 1、通过CocoaPods安装项目名称项目信息 AFNetworking网络请求组件 FMDB本地数据库组件 SD...
    阳明AI阅读 16,019评论 3 119
  • 世界上最窄的风景 莫过于北京的胡同 一场雨后 潮湿的路面泛着古老的气息 这场雨带走了以往的烦闷 连知了的叫声也被湮...
    AAAria阅读 184评论 0 0
  • 最好的年龄是,那一天,我们终于知道,并且坚定自己有多好。这不是自大,不是虚张,不是夸浮,不是众人捧,而是内心明明澈...
    leace1314阅读 860评论 4 5