SpringBoot日志系统

对springBoot底层日志实现的浅显的理解

查阅过相关资料后发现SpringBoot底层默认使用基于slf4j日志接口实现的日志框架logback来记录日志,
但是各种框架中默认使用的日志框架五花八门,在日常使用中如果不做处理的情况下使用日志则非常的麻烦,于是springBoot为了统一日志框架,底层使用logback,在兼容其他的框架的日志时springBoot使用了这样的一种方法:
1.首先剔除框架原本依赖的日志框架
2.导入日志转换工具包
3.导入实现了slf4j日志接口的日志框架
4.使用具体的日志记录框架来打印日志
首先在进行日志转换之前一定要剔除框架原本依赖的日志记录框架,否则在导入日志转换包之后会出现类的冲突,因为日志转换包内的具体实现是用与原框架依赖的日志框架相同的全限定类名来替换原日志框架的,替换后的类里面实则在真实调用的时候偷梁换柱让原本调用其他日志框架的类调用了我们具体实现日志功能的logback等。所以在项目中使用统一的日志时只需要剔除原框架的日志框架,再导入日志转换包即可。
其实在日志框架接口中使用了一种设计模式---->门面模式(外观模式)在调用loggerFactory.getLogger()时,底层原理是在类路径下的org.slf4j.impl.StaticLoggerBinder类来获取具体的logger的,但是在slf4j的jar包中并没有这个类,即slf4j并没有对日志功能有任何的实现,所以我们需要导入具体的日志实现类来实现具体的日志记录功能,所以只要是实现了slf4j日志接口的日志框架,jar包下就会有org.slf4j.impl.StaticLoggerBinder类,如果有多个实现类slf4j会使用自己内部的选择算法来选择一个具体的实现类并且会在控制台打印警告信息。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值