聊一聊帶智能提示的spring-boot-starter
前言
前幾個(gè)月和隔壁組的老王閑聊,他說項(xiàng)目的供應(yīng)商離職率居高不下,最近還有開發(fā)剛接手ESB訂閱發(fā)布接口才兩周就提出離職,而他能做的就只有苦笑和默默地接過這個(gè)爛攤子了。
而然幸福的家庭總是相似的,而不幸的我卻因業(yè)務(wù)變革走上了和老王一樣的道路。單單是接口的開發(fā)居然能迫使一位開發(fā)毅然決然地離職,我既不相信是人性的扭曲,更不信是道德的淪喪。
拋開這個(gè)富有色彩的故事而言,我發(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ā)人員大多只能依葫蘆畫瓢添加配置,既容易出錯(cuò)同時(shí)又增加問題排查的難度。
- 針對前兩個(gè)問題,我們只需梳理出必須的依賴項(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)完成一個(gè)基本的starter的功能
- 通過
@ConfigurationProperties
定義該starter注冊bean時(shí)需要的屬性集合 - 通過
@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
下, 若存在多個(gè)則用逗號分隔。
org.springframework.boot.autoconfigure.EnableAutoConfiguration = \ com.john.starter.EsbServerConfiguration,\ com.john.starter.OtherConfiguration
好與更好——集成IDE智能提示
應(yīng)用啟動時(shí)會將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
時(shí)會生成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)]一個(gè) 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的完整步驟
- 如何手寫一個(gè)Spring Boot Starter
相關(guān)文章
Java guava monitor監(jiān)視器線程的使用詳解
工作中的場景中是否存在類似這樣的場景,需要提交的線程在某個(gè)觸發(fā)條件下執(zhí)行。本文主要就是使用guava中的monitor來優(yōu)雅的實(shí)現(xiàn)帶監(jiān)視器的線程2021-11-11Java的Synchronized關(guān)鍵字學(xué)習(xí)指南(全面 & 詳細(xì))
這篇文章主要給大家介紹了關(guān)于Java的Synchronized關(guān)鍵字的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03JSON各種轉(zhuǎn)換問題(json轉(zhuǎn)List,json轉(zhuǎn)對象等)
這篇文章主要介紹了JSON各種轉(zhuǎn)換問題(json轉(zhuǎn)List,json轉(zhuǎn)對象等),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-03-03基于SpringBoot多線程@Async的使用體驗(yàn)
這篇文章主要介紹了SpringBoot多線程@Async的使用體驗(yàn),具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12SpringBoot集成Spring Security用JWT令牌實(shí)現(xiàn)登錄和鑒權(quán)的方法
這篇文章主要介紹了SpringBoot集成Spring Security用JWT令牌實(shí)現(xiàn)登錄和鑒權(quán)的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05idea快速搭建springboot項(xiàng)目的操作方法
下面小編就為大家分享一篇idea快速搭建springboot項(xiàng)目的操作方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12