Spring Boot自動化配置的利弊及解決之道
Spring Boot中的雙刃劍:自動化配置
在Spring Boot基礎(chǔ)教程系列文章中,我們通過各種功能性示例體驗了Spring Boot的自動化配置給我們所帶來的超便利的新開發(fā)方式。但是,在一些情況下Spring Boot的自動化配置也會給我們?nèi)莵聿簧俚穆闊热邕@些場景:
- 項目依賴復(fù)雜的情況下,由于依賴方的依賴組織不夠嚴格,可能引入了一些實際我們不需要的依賴,從而導(dǎo)致我們的項目滿足一些特定的自動化配置。
- 傳統(tǒng)Spring項目轉(zhuǎn)換為Spring Boot項目的過程中,由于不同的組織方式問題,引發(fā)自動化配置加載的錯誤,比如:通過xml手工組織的多數(shù)據(jù)源配置等。
上面這些原因都會導(dǎo)致不必要的自動化配置加載而導(dǎo)致應(yīng)用無法啟動或觸發(fā)/health的健康檢查不通過等問題。比如,我們在改造傳統(tǒng)Spring項目到Spring Boot項目中碰到的一些錯誤:
- 六月 21, 2017 6:23:47 下午 org.apache.catalina.loader.WebappClassLoaderBase clearReferencesThreads
- 警告: The web application [ROOT] appears to have started a thread named [Abandoned connection cleanup thread] but has failed to stop it. This is very likely to create a memory leak. Stack trace of thread:
- java.lang.Object.wait(Native Method)
- java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:143)
- com.mysql.jdbc.AbandonedConnectionCleanupThread.run(AbandonedConnectionCleanupThread.java:43)
- 2017-06-21 18:23:47,230 INFO [main] org.springframework.boot.autoconfigure.logging.AutoConfigurationReportLoggingInitializer -
- Error starting ApplicationContext. To display the auto-configuration report re-run your application with 'debug' enabled.
- 2017-06-21 18:23:47,237 ERROR [main] org.springframework.boot.diagnostics.LoggingFailureAnalysisReporter -
- ***************************
- APPLICATION FAILED TO START
- ***************************
- Description:
- Cannot determine embedded database driver class for database type NONE
- Action:
- If you want an embedded database please put a supported one on the classpath. If you have database settings to be loaded from a particular profile you may need to active it (no profiles are currently active).
從報錯信息中,我們就可以分析出錯誤原因是觸發(fā)了數(shù)據(jù)源的自動化配置,然而當(dāng)前項目其實并不需要數(shù)據(jù)源。查其根源是依賴方提供的API依賴中引用了一些多余的依賴觸發(fā)了該自動化配置的加載。
如何解決
為了解決上面所述的問題,我們可以用兩種方法來解決:
- 通過外部依賴的修改來解決:通過與依賴方溝通,在對方提供的API依賴中去掉不必要的依賴
- 通過禁用指定的自動化配置來避免加載不必要的自動化配置,下面列舉了禁用的方法:
使用了@EnableAutoConfiguration的時候
- @EnableAutoConfiguration(exclude={DataSourceAutoConfiguration.class})
使用了@SpringBootApplication的時候
- @SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
使用了@SpringCloudApplication的時候
- @EnableAutoConfiguration(exclude={DataSourceAutoConfiguration.class})
- @SpringCloudApplication
通過配置文件來設(shè)置
- spring.autoconfigure.exclude=org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration
【本文為51CTO專欄作者“翟永超”的原創(chuàng)稿件,轉(zhuǎn)載請通過51CTO聯(lián)系作者獲取授權(quán)】