聊一聊帶智能提示的spring-boot-starter
前言
前幾個月和隔壁組的老王閑聊,他說項(xiàng)目的供應(yīng)商離職率居高不下,最近還有開發(fā)剛接手ESB訂閱發(fā)布接口才兩周就提出離職,而他能做的就只有苦笑和默默地接過這個爛攤子了。
而然幸福的家庭總是相似的,而不幸的我卻因業(yè)務(wù)變革走上了和老王一樣的道路。單單是接口的開發(fā)居然能迫使一位開發(fā)毅然決然地離職,我既不相信是人性的扭曲,更不信是道德的淪喪。
拋開這個富有色彩的故事而言,我發(fā)現(xiàn)原來的項(xiàng)目存在如下問題:
- 有使用任何現(xiàn)代依賴管理和構(gòu)建工具(如Maven, Gradle),直接把所依賴的Jar包存放在項(xiàng)目目錄下的lib目錄中,日積月累導(dǎo)致lib目錄下存放大量無用Jar包;
- 沒有使用代碼版本管理工具管理代碼;
- 技術(shù)文檔欠缺,全靠師傅帶徒弟的方式傳授框架使用方式和開發(fā)流程;
- 機(jī)械性配置項(xiàng)多,而后來的開發(fā)人員大多只能依葫蘆畫瓢添加配置,既容易出錯同時又增加問題排查的難度。
- 針對前兩個問題,我們只需梳理出必須的依賴項(xiàng)并加入Maven或Gradle管理,然后托管到Git即可。
- 而后兩者則可以通過spring-boot-starter將必選依賴項(xiàng)和配置統(tǒng)一管理,并附上相關(guān)技術(shù)文檔;然后通過模板模式和注解簡化開發(fā)流程,提供Demo降低入門難度。
- 最后就可以把具體的業(yè)務(wù)功能開發(fā)交給供應(yīng)商處理,我們專心做好過程管理和驗(yàn)收即可。
本文將著重分享spring-boot-starter開發(fā)的事項(xiàng),請坐好扶穩(wěn)!
命名規(guī)范
在自定義starter前我們總要思考如何命名我們的starter,而官方提供如下的命名規(guī)范:
1.官方的starter以spring-boot-starter作為前綴命名項(xiàng)目
如:spring-boot-starter-web
2.非官方的則以spring-boot-starter作為后綴命名項(xiàng)目
如:mybatis-spring-boot-starter
項(xiàng)目結(jié)構(gòu)
通過Spring Initializr或Spring Boot CLI創(chuàng)建項(xiàng)目結(jié)構(gòu)后,將pom.xml的相關(guān)項(xiàng)目修改為如下內(nèi)容
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifacId> <version>2.3.1.RELEASE</version> <relativePath/> </parent> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <!-- 下面為自定義Starter的依賴項(xiàng) --> </dependencies> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <configuration> <source>1.8</source> <target>1.8</target> </configuration> </plugin> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-source-plugin</artifactId> <version>2.4</version> <executions> <execution> <goals> <goal>jar</goal> </goals> </execution> </executions> </plugin> </plugins> </build>
在starter中我們會定義SpringBean的注冊配置和屬性配置,如ESB訂閱服務(wù)的配置項(xiàng)目為
@Configuration
@EnableConfigurationProperties({EsbServerProperties.class})
public class EsbServerConfiguration {
@Bean
public SpringBus springBus(){
return new SpringBus();
}
@Bean
public LoggingFeature loggingFeature(){
return new LoggingFeature();
}
@Bean
public List<JMSConfigFeature> jmsConfigFeatures(EsbServerProperties props) throws JMSException {
List<JMSConfigFeature> features = new ArrayList<>();
/**
* 這里會使用EsbServerProperties的屬性構(gòu)建Bean實(shí)例
*/
return features;
}
}
屬性配置項(xiàng)
// 從application.yml等配置文件中讀取并綁定esb.server.destination等屬性值
@Data
@ConfigurationProperties("esb.server")
public class EsbServerProperties {
String destination;
int currConsumers = 1;
String channel;
int ccsid = 1205;
int transportType = 1;
List<String> connectionNameLists;
boolean replyError = false;
String replySuccessText = "Success";
String replyErrorText = "Failure";
}
到這里我們已經(jīng)完成一個基本的starter的功能
- 通過
@ConfigurationProperties定義該starter注冊bean時需要的屬性集合 - 通過
@Configuration定義該starter注冊的bean
但引用該starter的項(xiàng)目要如何啟用配置呢?其實(shí)有兩種方式,分別為手動和自動,其中我們會著重講解自動啟用配置。
手動啟用配置
所謂手動啟用配置其實(shí)就是在SpringBoot入口類上添加啟用配置用的自定義注解,針對上面的EsbServerConfiguration我們可以自定義EnableESBSrv注解
@Target(ElementType.TYPE)
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Import({EsbServerConfiguration.class})
public @interface EnableEsbSrv {
}
然后入口類的@SpringBootApplication注解前后添加@EnableEsbSrv即可。
讓人省心省力的自動啟用配置
自動啟用配置即只需在pom.xml中引入所依賴的starter,然后啟用應(yīng)用即可自動啟用該starter的@Configuration所注解的類從而注冊Bean和讀取屬性配置。
而這一切都是由AutoConfigurationImportSelector來操刀,而我們可以通過@EnableAutoConfiguration或@SpringBootApplication等實(shí)例化AutoConfigurationImportSelector類,配合菜譜resources/META-INF/spring.factories實(shí)現(xiàn)自動化配置的功能。
具體手法就是:將EsbServerConfiguration的全限類名稱寫在resources/META-INF/spring.factories的org.springframework.boot.autoconfigure.EnableAutoConfiguration下, 若存在多個則用逗號分隔。
org.springframework.boot.autoconfigure.EnableAutoConfiguration = \ com.john.starter.EsbServerConfiguration,\ com.john.starter.OtherConfiguration
好與更好——集成IDE智能提示
應(yīng)用啟動時會將application.yml中對應(yīng)的配置項(xiàng)綁定到@ConfigurationProperties標(biāo)注的類實(shí)例上,那么對于應(yīng)用開發(fā)人員而言日常工作就是修改application.yml的配置項(xiàng)。但I(xiàn)DE又缺少配置項(xiàng)的智能提示,那就很低效了。幸虧Spring Boot早就為我們提供好解決方案,分為手工和自動兩種。為了效率當(dāng)然是可以自動就不用手動的了。
1.Starter項(xiàng)目的工作引入spring-boot-configuration-processor依賴項(xiàng);
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-configuration-processor</artifactId> <optional>true</optional> </dependency>
2.若src/resources/META-INF/spring-configuration-metadata.json不存在,那么執(zhí)行mvn compile時會生成target/classes/META-INF/spring-configuration-metadata.json;
3.復(fù)制target/classes/META-INF/spring-configuration-metadata.json到src/resources/META-INF/spring-configuration-metadata.json即可。
業(yè)務(wù)系統(tǒng)項(xiàng)目的工作
1.引入spring-boot-configuration-processor依賴項(xiàng);
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-configuration-processor</artifactId> <optional>true</optional> </dependency>
IDEA安裝Spring Assistant插件,并啟用Enable annotation processing(勾選 Settings/Build, Execution & Deployment/Compiles/Annotation Processors/Enable annotation processing)。
總結(jié)
spring-boot-starter非常適合用于團(tuán)隊(duì)的技術(shù)積累和沉淀,不過想恰到好處地應(yīng)用起來,不僅要需要深入Spring內(nèi)部原理還要梳理清楚業(yè)務(wù)邏輯。后續(xù)我們再深入探討Spring內(nèi)核的事情吧!
到此這篇關(guān)于聊一聊帶智能提示的spring-boot-starter的文章就介紹到這了,更多相關(guān)springboot starter智能提示內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 手?jǐn)]一個 spring-boot-starter的全過程
- 使用SpringBoot自定義starter的完整步驟
- SpringBoot自動配置之自定義starter的實(shí)現(xiàn)代碼
- springboot自定義redis-starter的實(shí)現(xiàn)
- SpringBoot2.1.x,創(chuàng)建自己的spring-boot-starter自動配置模塊操作
- SpringBoot如何實(shí)現(xiàn)starter原理詳解
- SpringBoot啟動器Starters使用及原理解析
- springboot自定義starter實(shí)現(xiàn)過程圖解
- Spring Boot企業(yè)常用的starter示例詳解
- Spring boot創(chuàng)建自定義starter的完整步驟
- 如何手寫一個Spring Boot Starter
相關(guān)文章
使用lombok@Data啟動項(xiàng)目報錯問題及解決
在使用Lombok時,可能會遇到實(shí)體類中的@Data注解不生效,導(dǎo)致get方法找不到的問題,解決這一問題通常需要三個步驟:首先,檢查項(xiàng)目設(shè)置中編譯規(guī)則是否勾選;其次,確認(rèn)IDE中是否安裝了Lombok插件2024-10-10
淺談Java內(nèi)部類——靜態(tài)內(nèi)部類
這篇文章主要介紹了Java靜態(tài)內(nèi)部類的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)Java內(nèi)部類的相關(guān)知識,感興趣的朋友可以了解下2020-08-08
Java異常 Exception類及其子類(實(shí)例講解)
下面小編就為大家?guī)硪黄狫ava異常 Exception類及其子類(實(shí)例講解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-11-11
Java中ArrayList和LinkedList的區(qū)別
ArrayList和LinkedList在這個方法上存在一定的性能差異,本文就介紹了Java中ArrayList和LinkedList的區(qū)別,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06
springboot中@ConfigurationProperties無效果的解決方法
本文主要介紹了springboot中@ConfigurationProperties無效果,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-06-06
Java selenium處理極驗(yàn)滑動驗(yàn)證碼示例
本篇文章主要介紹了Java selenium處理極驗(yàn)滑動驗(yàn)證碼示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10
Mybatis中的resultType和resultMap查詢操作實(shí)例詳解
resultType是直接表示返回類型的,而resultMap則是對外部ResultMap的引用,resultMap解決復(fù)雜查詢是的映射問題。這篇文章主要介紹了Mybatis中的resultType和resultMap查詢操作實(shí)例詳解,需要的朋友可以參考下2016-09-09

