關(guān)于SpringBoot3.x中spring.factories功能被移除的解決方案
背景
筆者所在項(xiàng)目組在搭建一個(gè)全新項(xiàng)目的時(shí)候選用了SpringBoot3.x,項(xiàng)目中應(yīng)用了很多SpringBoot2.x時(shí)代相關(guān)的第三方組件例如baomidou出品的mybatis-plus、dynamic-datasource等。在配置好相關(guān)依賴、最小啟動(dòng)類和配置之后,發(fā)現(xiàn)項(xiàng)目無(wú)法啟動(dòng)。于是根據(jù)啟動(dòng)上下文日志和按行DEBUG找到原因并且在等待組件升級(jí)兼容之前進(jìn)行臨時(shí)性解決。
關(guān)于spring.factories
spring.factories其實(shí)是SpringBoot提供的SPI機(jī)制,底層實(shí)現(xiàn)是基于SpringFactoriesLoader檢索ClassLoader中所有jar(包括ClassPath下的所有模塊)引入的META-INF/spring.factories文件,基于文件中的接口(或者注解)加載對(duì)應(yīng)的實(shí)現(xiàn)類并且注冊(cè)到IOC容器。這種方式對(duì)于@ComponentScan不能掃描到的并且想自動(dòng)注冊(cè)到IOC容器的使用場(chǎng)景十分合適,基本上絕大多數(shù)第三方組件甚至部分spring-projects中編寫的組件都是使用這種方案。

spring.factories文件的格式大致如下:
# Initializers org.springframework.context.ApplicationContextInitializer=\ org.springframework.boot.autoconfigure.SharedMetadataReaderFactoryContextInitializer,\ org.springframework.boot.autoconfigure.logging.ConditionEvaluationReportLoggingListener # Application Listeners org.springframework.context.ApplicationListener=\ org.springframework.boot.autoconfigure.BackgroundPreinitializer # Environment Post Processors org.springframework.boot.env.EnvironmentPostProcessor=\ org.springframework.boot.autoconfigure.integration.IntegrationPropertiesEnvironmentPostProcessor # Auto Configuration Import Listeners org.springframework.boot.autoconfigure.AutoConfigurationImportListener=\ org.springframework.boot.autoconfigure.condition.ConditionEvaluationReportAutoConfigurationImportListener # Auto Configuration Import Filters org.springframework.boot.autoconfigure.AutoConfigurationImportFilter=\ org.springframework.boot.autoconfigure.condition.OnBeanCondition,\ org.springframework.boot.autoconfigure.condition.OnClassCondition,\ org.springframework.boot.autoconfigure.condition.OnWebApplicationCondition org.springframework.boot.autoconfigure.EnableAutoConfiguration=\ com.baomidou.mybatisplus.autoconfigure.MybatisPlusLanguageDriverAutoConfiguration,\ com.baomidou.mybatisplus.autoconfigure.MybatisPlusAutoConfiguration
通用格式是:接口(或者注解)全類名=\接口實(shí)現(xiàn)類(或者使用了該注解的類)全類名-1,\接口實(shí)現(xiàn)類(或者使用了該注解的類)全類名-2,\...接口實(shí)現(xiàn)類(或者使用了該注解的類)全類名-n。spring.factories中最常用的注解是org.springframework.boot.autoconfigure.EnableAutoConfiguration,通過(guò)配置此注解對(duì)應(yīng)的實(shí)現(xiàn)了,底層會(huì)由AutoConfigurationImportSelector對(duì)響應(yīng)的目標(biāo)類進(jìn)行加載和自動(dòng)注冊(cè)。通過(guò)閱讀Spring Boot 3.0 Migration Guide得知,spring.factories功能在Spring Boot 2.7已經(jīng)廢棄,并且會(huì)在Spring Boot 3.0移除。
spring.factories被移除后的替代方案
Spring Boot 2.x升級(jí)到Spring Boot 3.0其實(shí)是一個(gè)"破壞性"升級(jí),目前來(lái)看相對(duì)較大的影響是:
- 必須使用
JDK17 Jakarta EE的引入,導(dǎo)致很多舊的類包名稱改變- 部分類被徹底移除
spring-data模塊的所有配置屬性必須使用spring.data前綴,例如spring.redis.host必須更變?yōu)?code>spring.data.redis.hostspring.factories功能在Spring Boot 2.7已經(jīng)廢棄,在Spring Boot 3.0徹底移除(見(jiàn)下圖)

替代方案比較簡(jiǎn)單,就是在類路徑下創(chuàng)建META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports文件,文件的內(nèi)容是:每個(gè)實(shí)現(xiàn)類的全類名單獨(dú)一行。例如對(duì)于使用了(低版本還沒(méi)適配Spring Boot 3.0)mybatis-plus、dynamic-datasource組件的場(chǎng)景,可以在項(xiàng)目某個(gè)模塊的resources目錄下建立META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports文件,輸入以下內(nèi)容:
com.baomidou.dynamic.datasource.spring.boot.autoconfigure.DynamicDataSourceAutoConfiguration com.baomidou.mybatisplus.autoconfigure.MybatisPlusLanguageDriverAutoConfiguration com.baomidou.mybatisplus.autoconfigure.MybatisPlusAutoConfiguration
對(duì)于某些社區(qū)熱度比較高的組件近期可以密切關(guān)注其基于Spring Boot 3.0適配的版本發(fā)布,例如mybatis-spring、dubbo等:

這里還沒(méi)詳細(xì)分析META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports的源碼實(shí)現(xiàn),從描述和文件名來(lái)看,大致看出它在使用上跟原來(lái)的spring.factories文件中編寫org.springframework.boot.autoconfigure.EnableAutoConfiguration是相同的
小結(jié)
Spring Boot 3.0的升級(jí)門檻比較高。目前來(lái)看spring.factories功能的移除個(gè)人認(rèn)為是本次版本升級(jí)的最大影響因素,有可能導(dǎo)致大部分第三方編寫過(guò)自動(dòng)注冊(cè)板塊的組件全部失效。當(dāng)然,JDK17也是一個(gè)比較高的門檻,對(duì)于大部分有歷史包袱的項(xiàng)目如果決定升級(jí)需要極大的容器。建議先觀望和關(guān)注團(tuán)隊(duì)用到的技術(shù)?;蛘呖蚣芏歼m配Spring Boot 3.0后再進(jìn)行版本升級(jí)。
到此這篇關(guān)于SpringBoot3.x中spring.factories功能被移除的解決方案的文章就介紹到這了,更多相關(guān)SpringBoot3.x中spring.factories功能移除內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Spring中的spring.factories文件用法(Spring如何加載第三方Bean)
- springboot自動(dòng)配置原理以及spring.factories文件的作用詳解
- springboot 加載 META-INF/spring.factories方式
- SpringBoot借助spring.factories文件跨模塊實(shí)例化Bean
- SpringBoot?spring.factories加載時(shí)機(jī)分析
- springBoot?之spring.factories擴(kuò)展機(jī)制示例解析
- SpringBoot 自動(dòng)掃描第三方包及spring.factories失效的問(wèn)題解決
- SpringBoot3.x中spring.factories?SPI?服務(wù)發(fā)現(xiàn)機(jī)制的改變問(wèn)題小結(jié)
- SpringBoot之spring.factories的使用方式
- 在SpringBoot3中spring.factories配置不起作用的原因和解決方法
- 淺談spring.factories文件的作用
相關(guān)文章
Mybatis-Plus 自動(dòng)填充失效問(wèn)題解決
在使用MyBatis-Plus時(shí),自動(dòng)填充功能可能會(huì)失效,這通常與版本和配置有關(guān),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-10-10
MyBatisPlus中事務(wù)處理的實(shí)現(xiàn)
本文主要介紹了MyBatisPlus中事務(wù)處理的實(shí)現(xiàn),包括事務(wù)的開(kāi)啟、提交、回滾等操作,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-07-07
Spring Boot 2.0快速構(gòu)建服務(wù)組件全步驟
這篇文章主要給大家介紹了關(guān)于Spring Boot 2.0快速構(gòu)建服務(wù)組件的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Spring Boot 2.0具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
springboot整合shiro與自定義過(guò)濾器的全過(guò)程
這篇文章主要給大家介紹了關(guān)于springboot整合shiro與自定義過(guò)濾器以及Shiro中權(quán)限控制的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-01-01
基于hibernate實(shí)現(xiàn)的分頁(yè)技術(shù)實(shí)例分析
這篇文章主要介紹了基于hibernate實(shí)現(xiàn)的分頁(yè)技術(shù),結(jié)合實(shí)例形式分析了Hibernate分頁(yè)技術(shù)的原理,實(shí)現(xiàn)步驟與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-03-03
Java中public關(guān)鍵字用法詳細(xì)講解
這篇文章主要給大家介紹了關(guān)于Java中public關(guān)鍵字用法的相關(guān)資料,public關(guān)鍵字是和訪問(wèn)權(quán)限相關(guān)的,它所修飾的方法對(duì)所有類都是可以訪問(wèn)的,需要的朋友可以參考下2023-09-09

