SpringBoot —— 日志框架

SpringBoot —— 日志框架一、类比 JDBC—数据库驱动的架构(门面设计模式)1. 在我们开发应用的场景中,需要用到很多jar包,而这些包又有自己的日志框架那么,如何实现便捷的切换日志记录框架?解决:首先,写了一个统一的接口层 SLF4J,作为日志门面(日志的一个抽象层),例如:logging-abstract.jar;想用哪个日志框架(实现了日志门面接口),就给项目中导入具体的日志实现就行了;如果不能直接作为 SLF4J 的日志实现,例如:log4j,可以在中间使用一个适配层
摘要由CSDN通过智能技术生成

一、类比 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&
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: SpringBoot是一个用于开发Java应用程序的框架,它提供了一种简化的方式来构建独立的、生产级别的应用程序。在SpringBoot中,我们可以使用SpringBootServletInitializer的子类来配置应用程序的启动方式。这个子类需要重写configure方法,并传入SpringBoot应用的主程序。通过这种方式,我们可以将SpringBoot应用打包成war文件并部署到Servlet容器中。\[1\] 在使用SpringBoot时,我们可以使用Maven来管理所有的jar包依赖。Maven是一个强大的项目管理工具,它可以帮助我们自动下载和管理项目所需的依赖库。类似地,SpringBoot也提供了一些启动器,这些启动器包含了常用的框架和库的依赖,可以方便地集成到我们的应用程序中。通过在pom.xml文件中添加相应的依赖,我们可以快速引入所需的功能和组件。\[2\] 在SpringBoot中,默认使用SLF4J和Logback作为日志框架。SLF4J是一个简单的日志门面,它提供了统一的日志接口,可以方便地切换不同的日志实现。Logback是SLF4J的一个实现,它提供了高性能和灵活的日志功能。在SpringBoot中,我们可以通过添加spring-boot-starter-logging依赖来引入默认的日志配置。这样,我们就可以使用SpringBoot提供的日志功能来记录应用程序的运行日志。\[3\] #### 引用[.reference_title] - *1* *2* *3* [【开发】后端框架——SpringBoot](https://blog.csdn.net/qq_40479037/article/details/129786063)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值