一、类比 JDBC—数据库驱动的架构(门面设计模式)
1. 在我们开发应用的场景中,需要用到很多jar包,而这些包又有自己的日志框架
那么,如何实现便捷的切换日志记录框架?
解决:
首先,写了一个统一的接口层 SLF4J,作为日志门面(日志的一个抽象层),例如:logging-abstract.jar;
想用哪个日志框架(实现了日志门面接口),就给项目中导入具体的日志实现就行了;
如果不能直接作为 SLF4J 的日志实现,例如:log4j,可以在中间使用一个适配层
上图 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进行输出?
解决办法:引入中间替换包
- 将系统中其他日志框架先排除出去;
- 用中间包来替换原有的日志框架;
- 我们导入slf4j其他的实现。
如下图做法:
以log4j为例:
SpringBoot 引入中间替换包把其他的日志都替换成了 slf4j
3. 如何移除依赖jar包?
比如 Spring 使用的是 commons-logging 框架,我们可以这样移除:
<dependency>
<groupId>org.springframework</groupId&