SLF4J源码解析(一)

本文探讨SLF4J如何在代码中整合不同日志框架,通过源码分析`bind()`和`findPossibleStaticLoggerBinderPathSet()`方法揭示其工作原理。SLF4J依赖于各日志框架的`StaticLoggerBinder`实现`LoggerFactoryBinder`接口,确保Class Path中只能有一种日志框架的binding,以避免冲突。
摘要由CSDN通过智能技术生成

提出问题

阅读源码之前,首先提几个问题

  • SLF4J是如何整合不同的日志框架的
  • Class Path中为什么只能有且仅有一种日志框架的binding

这段文字摘录自官网:In your code, in addition to slf4j-api-1.8.0-beta2.jar, you simply drop one and only one binding of your choice onto the appropriate class path location. Do not place more than one binding on your class path.

源码版本

  • org.slf4j:slf4j-api:1.7.25
  • org.apache.logging.log4j:log4j-slf4j-impl:2.11.1
  • ch.qos.logback:logback-classic:1.2.3
  • org.slf4j:slf4j-jcl:1.7.25

源码解析

带着上面的两个问题看下源码

  1. bind()方法中通过调用findPossibleStaticLoggerBinderPathSet()方法来查找日志框架的绑定

  1. findPossibleStaticLoggerBinderPathSet()方法中通过ClassLoader或者loggerFactoryClassLoader来获取名为"STATIC_LOGGER_BINDER_PATH"的Resources "STAT
SLF4J: Class path contains multiple SLF4J providers是一个错误信息,表示在项目的classpath中存在多个SLF4J提供者。这个问题通常会导致SLF4J无法确定使用哪个提供者,从而引发错误。 解决这个问题的方法是删除或排除冲突的SLF4J提供者。可以通过以下步骤来解决这个问题: 1. 首先,需要确定项目的依赖关系,尤其是与日志相关的依赖项。查看项目的pom.xml文件或构建配置文件,找到与SLF4J相关的依赖项。 2. 接下来,需要确定哪些依赖项导致了冲突。查找冲突的SLF4J提供者,可以在错误信息中找到类似"Found binding in"的内容,它会列出存在冲突的路径以及提供者的名称。 3. 一旦确定了冲突的提供者,可以选择将其中一个提供者从项目中移除。这可以通过在项目配置文件中排除依赖项或手动删除相关的jar文件来实现。 4. 如果移除冲突的提供者后仍然存在问题,可能需要查看项目的其他依赖项,确保它们与SLF4J的版本兼容。 总的来说,当出现SLF4J: Class path contains multiple SLF4J providers错误时,需要检查项目的依赖关系,找出冲突的SLF4J提供者并进行相应的调整。这样可以确保SLF4J能够正常工作并连接到正确的日志实现。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [IDEA运行报错:slf4j:Class path contains multiple SLF4J bindings. SLF4J: Found binding in [jar:file:/...](https://blog.csdn.net/qq_44425201/article/details/120863321)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [SLF4J(二) - SLF4J绑定了多个实现类的错误是怎么一回事儿?源码解析](https://blog.csdn.net/sweetyi/article/details/104633321)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值