logback自定义json日志输出示例详解

 更新时间:2022年03月01日 10:48:42   作者:kl  
这篇文章主要为大家介绍了logback自定义json日志输出,就是通过logback日志体系以及logstash提供的json log依赖将数据以json格式记录到日志文件的例子

前言

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

依赖的jar

logstash-logback-encoder : https://github.com/logfellow/logstash-logback-encoder

maven坐标

<dependency>
    <groupId>net.logstash.logback</groupId>
    <artifactId>logstash-logback-encoder</artifactId>
    <version>5.2</version>
</dependency>

配置Appender节点

<appender name="jsonLog" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <File>${logging.path}/customerBuriedPoint.log</File>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${logging.path}/customerBuriedPoint.%d{yyyy-MM-dd}.log</fileNamePattern>
        </rollingPolicy>
        <encoder class="net.logstash.logback.encoder.LoggingEventCompositeJsonEncoder">
            <jsonFactoryDecorator class="net.logstash.logback.decorate.CharacterEscapesJsonFactoryDecorator">
                <escape>
                    <targetCharacterCode>10</targetCharacterCode>
                    <escapeSequence>\u2028</escapeSequence>
                </escape>
            </jsonFactoryDecorator>
            <providers>
                <pattern>
                    <pattern>
                        {
                        "timestamp":"%date{ISO8601}",
                        "userId":"%mdc{userId}",
                        "requestIp":"%mdc{requestIp}",
                        "event":"%mdc{event}"
                        }
                    </pattern>
                </pattern>
            </providers>
        </encoder>
    </appender>

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" level="info" additivity="false">
        <appender-ref ref="jsonLog"/>
    </logger>

logger配置说明:

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

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

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

以上就是logback自定义json日志输出示例详解的详细内容,更多关于logback自定义json日志输出的资料请关注脚本之家其它相关文章!

相关文章

  • SpringBoot2 整合FreeMarker实现页面静态化示例详解

    SpringBoot2 整合FreeMarker实现页面静态化示例详解

    这篇文章主要介绍了SpringBoot2 整合FreeMarker实现页面静态化示例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • SpringBoot 转发请求至指定页面的操作方法

    SpringBoot 转发请求至指定页面的操作方法

    这篇文章主要介绍了SpringBoot 转发请求至指定页面,需要使用@Controller,不可使用@RestController,@RestController相当于@Controller和@ResponseBody合在一起的作用,本文通过实例代码详细讲解,需要的朋友可以参考下
    2022-11-11
  • 如何解决Java程序包不存在问题

    如何解决Java程序包不存在问题

    在使用IDEA 2022版本和Maven项目中,可能遇到Java程序包不存在的问题,这是由于IDEA的小bug引起的,文章提供了两种解决方法:第一种是在IDEA的Settings中配置,并在pom.xml中添加特定代码刷新Maven;第二种是通过IDEA的设置菜单修改Maven导入配置
    2024-10-10
  • Java线程安全中的单例模式

    Java线程安全中的单例模式

    这篇文章主要介绍了Java线程安全中的单例模式,需要的朋友可以参考下
    2015-02-02
  • zookeeper监听器原理的详解

    zookeeper监听器原理的详解

    今天小编就为大家分享一篇关于zookeeper监听器原理的详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • java解压zip文件示例

    java解压zip文件示例

    这篇文章主要介绍了java解压zip文件示例,在获得一个以Zip格式压缩的文件之后,需要将其进行解压缩,还原成压缩前的文件,下面是代码示例
    2014-03-03
  • Java实现读取文章中重复出现的中文字符串

    Java实现读取文章中重复出现的中文字符串

    本文主要介绍了Java实现读取文章中重复出现的中文字符串的方法。具有很好的参考价值。下面跟着小编一起来看下吧
    2017-03-03
  • 详解Java中的反射机制和动态代理

    详解Java中的反射机制和动态代理

    本文将详细介绍反射机制以及动态代理机制,而且基本现在的主流框架都应用了反射机制,如spring、MyBatis、Hibernate等等,这就有非常重要的学习意义
    2021-06-06
  • Java创建线程三种方式的优缺点

    Java创建线程三种方式的优缺点

    今天小编就为大家分享一篇关于Java创建线程三种方式的优缺点,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • java实现Api接口加密通信方式

    java实现Api接口加密通信方式

    这篇文章主要介绍了java实现Api接口加密通信方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06

最新评论