IT俱乐部 Java SpringBoot集成slf4j2日志配置的实现示例

SpringBoot集成slf4j2日志配置的实现示例

简介

本章节主要介绍springboot项目集成slf4j2,看完本章内容可以轻松完成集成。另外说一下,在对日志输出场景比较多的情况下可以考虑将logback更换为log4j2。

1、pom引入依赖

        org.projectlomboklombok1.18.24org.springframework.bootspring-boot-starter-log4j23.1.0

2、剔除依赖

在springboot 中默认的日志管理就是logback,需要剔除原来的日志包引用,凡是相关的springboot都需要exclusion日志包,下面举例说明

		org.springframework.bootspring-boot-starter2.7.13org.springframework.bootspring-boot-starter-loggingorg.springframework.bootspring-boot-starter-web2.7.13org.springframework.bootspring-boot-starter-logging

3、创建log4j2.xml配置文件

在resource目录下创建log4j2.xml文件,log4j2.xml配置详情如下:

3.1、配置文件内容


3.2、配置参数详解

日志等级说明

等级 说明
trace 追踪,就是程序推进一下,可以写个trace输出
debug 调试,一般作为最低级别,trace基本不用
info 输出重要的信息,使用较多
warn 警告,有些信息不是错误信息,但也要给程序员一些提示。
error 错误信息。用的也很多
fatal 致命错误

输出源

类别 说明
CONSOLE 输出到控制台
FILE 输出到文件

格式

类别 说明
SimpleLayout 以简单的形式显示
HTMLLayout 以HTML表格显示
PatternLayout 自定义形式显示

PatternLayout自定义日志布局:

格式 说明
%d{HH:mm:ss.SSS} 表示输出到毫秒的时间
%t 输出当前线程名称
%-5level 输出日志级别,-5表示左对齐并且固定输出5个字符,如果不足在右边补0
%logger 输出logger名称
%msg 日志文本
%n 换行
%F 输出所在的类文件名,如Test.java
%L 输出行号
%M 输出所在方法名
%l 输出语句所在的行数, 包括类名、方法名、文件名、行数

4、application.yml文件配置

需要指定加在的配置文件,因为默认加载的文件名为log4j2-spring.xml

logging:
  config: classpath:log4j2.xml
  level:
    root: trace

5、测试

写一段测试代码打印日志,启动项目进行测试即可

@Slf4j
public class Test {

    @GetMapping(value = "/testFeign", produces = MediaType.APPLICATION_JSON_VALUE)
    public Result testFeign() {
        log.info("测试feign调用------biz");
        return Result.success(true);
    }

}

6、附录

6.1、集成异常一

如果启动的时候出现如下错误,则需要

SLF4J: Failed to load class “org.slf4j.impl.StaticLoggerBinder”.
SLF4J: Defaulting to no-operation (NOP) logger implementation

解决方法:引入如下依赖即可

 		org.slf4jslf4j-nop1.7.36

6.2、 log4j2特性

(1)数据丢失少,可以用来做审计功能。自身内部报的exception会被发现,但是logback和log4j不会;
(2)log4j2使用了disruptor技术,在多线程环境下,性能高于logback等10倍以上;
(3)(garbage free)之前的版本会产生非常多的临时对象,会造成GC频繁,log4j2则在这方面上做了优化,减少产生临时对象。尽可能少的GC,其实也是基于disruptor技术;
(4)支持lambda表达式;
(5)对filter的功能支持的更强大;
(6)系统日志(Syslog)协议支持TCP 和 UDP
(7)支持kafka queue

6.3、 log4j2异步日志的四种队列

列出了log4j2异步日志的四种队列,有兴趣可以深入了解

ArrayBlockingQueue -- 默认的队列,通过 java 原生的 ArrayBlockingQueue 实现。
LinkedTransferQueue -- 通过 java7 以上原生支持的 LinkedTransferQueue 实现。
DisruptorBlockingQueue -- disruptor 包实现的高性能队列。
JCToolsBlockingQueue -- JCTools 实现的无锁队列。

6.4 、log4j2使用了disruptor技术

Disruptor有三大杀器 CAS、消除伪共享、RingBuffer
Disruptor通过以下设计来解决队列速度慢的问题:

环形数组结构

为了避免垃圾回收, 采用数组而非链表. 同时, 数组对处理器的缓存机制更加友好。
类似的实现思想还有其他应用:

disruptor mysql linux 内核
RingBuffer 环形队列实现 redolog通过一个环形的存储区域实现其循环写入 进程间通信所使用的 fifo 通过环形存储区域
  • 元素位置定位

    数组长度2^n, 通过位运算, 加快定位的速度. 下标采取递增的形式. 不用担心index溢出的问题. index是long类型, 即使100万QPS的处理速度, 也需要30万年才能用完。

  • 无锁设计

    每个生产者或者消费者线程, 会先申请可以操作的元素在数组中的位置, 申请到之后, 直接在该位置写入或者读取数据。

到此这篇关于SpringBoot集成slf4j2日志配置的实现示例的文章就介绍到这了,更多相关SpringBoot slf4j2日志配置内容请搜索IT俱乐部以前的文章或继续浏览下面的相关文章希望大家以后多多支持IT俱乐部! 

本文收集自网络,不代表IT俱乐部立场,转载请注明出处。https://www.2it.club/code/java/13192.html
上一篇
下一篇
联系我们

联系我们

在线咨询: QQ交谈

邮箱: 1120393934@qq.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部