SpringBoot —— 日志框架

本文详细介绍了SpringBoot日志框架的整合,包括类比JDBC的门面设计模式,SpringBoot的日志记录细节,市面上的日志框架如SLF4J,以及日志level的使用。重点讲解了如何通过SLF4J实现日志框架的统一,并提供了移除其他日志框架依赖的方法,以及自定义日志配置的实践案例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、类比 JDBC—数据库驱动的架构(门面设计模式)

1. 在我们开发应用的场景中,需要用到很多jar包,而这些包又有自己的日志框架

那么,如何实现便捷的切换日志记录框架?

解决:

首先,写了一个统一的接口层 SLF4J,作为日志门面(日志的一个抽象层),例如:logging-abstract.jar;

想用哪个日志框架(实现了日志门面接口),就给项目中导入具体的日志实现就行了;

如果不能直接作为 SLF4J 的日志实现,例如:log4j,可以在中间使用一个适配层
UMfIB9.png

上图 slf4j 有六种用法,一共五种角色,
	application 不用说,就是我们的系统;
	SLF4J API 就是日志接口层(门面);
	蓝色和最下面灰色的就是具体日志实现(子系统);
	而 Adaptation 就是适配层。

上图第二,第三种用法。
其中第二种就是 SpringBoot 的默认用法;
而为什么会出现第三种?
因为 Log4J 出现得比较早,它根本不知道后面会有 SLF4J 这东西。
Log4J 不能直接作为 SLF4J 的日志实现,所以中间就出现了适配层。第四种同理。

注意:

这里提醒下,每一个日志的实现框架都有自己的配置文件。使用 slf4j 以后,配置文件还是做成日志实现框架自己本身的配置文件。比如,Logback 就使用 logback.xml、Log4j 就使用 Log4j.xml 文件。


2. 如何让应用中所有的日志框架都统一使用 slf4j ?

我们自己的应用SpringBoot中启用了 Logback 这个日志框架;我们又整合了框架 Hibernate,Hibernate 中使用的日志框架为 jboss-logging:我们的应用SpringBoot又使用了 Spring ,Spring 中使用的日志框架为 commons-logging。

这就引出,如何统一日志记录,即使是别的框架和我一起统一使用slf4j进行输出?

解决办法:引入中间替换包

  1. 将系统中其他日志框架先排除出去;
  2. 用中间包来替换原有的日志框架;
  3. 我们导入slf4j其他的实现。

如下图做法:
UMhvGV.png

以log4j为例:
SpringBoot 引入中间替换包把其他的日志都替换成了 slf4j
UM4aLQ.png


3. 如何移除依赖jar包?

比如 Spring 使用的是 commons-logging 框架,我们可以这样移除:

<dependency>
    <groupId>org.springframework</groupId>
        <artifactId>spring-core</artifactId>
            <exclusions>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值