logback日志pattern_logback自定义json日志输出

前言碎语

先说下楼主的使用场景吧,将程序的某些方法调用以json格式的内容记录到文件中,提供给大数据做数据分析用。当然这个需求实现起来很简单,通过aop拦截切面统一输出内容到文件即可。下面要介绍的就是通过logback日志体系以及logstash提供的json log依赖将数据以json格式记录到日志文件的例子。

依赖的jar

maven坐标

net.logstash.logback

logstash-logback-encoder

5.2

配置Appender节点

${logging.path}/customerBuriedPoint.log

${logging.path}/customerBuriedPoint.%d{yyyy-MM-dd}.log

10

\u2028

{

"timestamp":"%date{ISO8601}",

"userId":"%mdc{userId}",

"requestIp":"%mdc{requestIp}",

"event":"%mdc{event}"

}

appender配置说明:

encoder:其他的所有配置logback该怎么配置就怎么配置,重点是logstash提供的LoggingEventCompositeJsonEncoder,一个json格式的编码器。

jsonFactoryDecorator:解决中文转码的问题,不加这个的话中文会被编码成ASCII码输出

providers:json格式提供者,想要什么字段的json就定义什么,logevent中的类型都可以在这里直接定义输出,比如,timestamp,message,thread_name等,其他的自定义的字段的值可以通过MDC设置进来,格式就是%mdc{xx},其中xx就是你日志上下文MDC中设置的值,比如MDC.put("requestIp",requestIp);

配置logger节点

logger配置说明:

这里定义了name为buriedPoint的logger节点,那么日志系统中,只会输出定义为buriedPoint的日志,比如:

Logger logger = LoggerFactory.getLogger("buriedPoint");

最终实现的效果如下图所示:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值