【日常记录-Java】SLF4J扫描实现框架的过程

1. 简介

        SLF4J(Simple Logging Facade for Java)作为一种简单的门面或抽象,服务于其他各种日志框架,例如JUL、log4j、logback等,核心作用有两项:

  • 提供日志接口;
  • 提供获取具体日志对象的方法;

2. 扫描过程

  2.1 引入依赖

        在使用SLF4J时,需要引入其API依赖以及一个具体日志实现框架的依赖,如logback、log4j;

  2.2 服务加载

        从2.0.0版本开始,SLF4J通过Java的SPI(Service Provider Interface)技术来加载当前classpath下配置的SLF4JServiceProvider;在SPI包下,SLF4J定义了一个接口SLF4JServiceProvider,具体的日志实现框架会提供一个实现类,并配置在META-INF/services/org.slf4j.spi.SLF4JServiceProvider文件中;

  2.3 初始化过程

        当调用LoggerFactory的getLogger方法时,SLF4J会尝试加载并初始化一个SLF4JServiceProvider;

        若在classpath下找到了配置的SLF4JServiceProvider实现类,则使用该实现进行初始化;若未找的,则使用默认的NOPServiceProvider,该provider提供的logger不会输出任何东西;

  2.4 获取日志对象

        通过初始化后的SLF4JServiceProvider,可以获取到一个ILoggerFactory接口的实现,在通过该实现获取具体的Logger对象;

  2.5 日志记录

        使用获取到的Logger对象,可以调用其提供的日志记录方法(如info、error等)进行日志记录;这些日志记录方法会调用具体的日志实现框架来进行日志输出;

3. SLF4J的优势与特点

  • 解耦:通过引入SLF4J作为日志门面,可以将日志记录与具体的日志实现框架解耦,使得在更换日志实现框架时无需修改大量的代码;
  • 统一接口:SLF4J提供了统一的日志接口,使得开发者可以更加方便地进行日志记录;

4. 注意事项

  • 避免多个实现框架共存:同一个项目中,应避免同时引入多个SLF4J的实现框架,否则可能会导致冲突和不确定的行为;
  • 正确配置:应确保SLF4J的SPI配置文件(如META-INF/services/org.slf4j.spi.SLF4JServiceProvider)正确配置,以便SLF4J能够正确加载和初始化所需的日志实现框架;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我叫白小猿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值