springboot項(xiàng)目啟動(dòng)慢的問題排查方式
springboot項(xiàng)目啟動(dòng)慢的問題排查
springboot項(xiàng)目,隨著時(shí)間的推移,啟動(dòng)耗時(shí)逐步增加,從幾分鐘慢慢的達(dá)到30多分鐘,有點(diǎn)恐怖!
項(xiàng)目中用到技術(shù):hibernate、redis、kafka、線程池等,啟動(dòng)慢的環(huán)境使用的是mysql數(shù)據(jù)庫!
1.最開始查看的啟動(dòng)日志,是在輸出:
org.hibernate.id.UUIDHexGenerator : HHH000409: Using org.hibernate.id.UUIDHexGenerator which does not generate IETF RFC 4122 compliant UUID values; consider using org.hibernate.id.UUIDGenerator instead
后停滯,等相當(dāng)長時(shí)間后繼續(xù)輸出:
o.s.s.concurrent.ThreadPoolTaskExecutor : Initializing ExecutorService 'taskExecutor'

懷疑是創(chuàng)建kafka、線程池等導(dǎo)致耗時(shí),通過去掉相關(guān)對象創(chuàng)建,耗時(shí)仍無改觀!
2. 啟動(dòng)項(xiàng)目,打印日志級別改為debug,查看更詳細(xì)信息


發(fā)現(xiàn):大量的alter table 增加外鍵!奇怪,不是第一次啟動(dòng)項(xiàng)目,mysql庫中的表早已創(chuàng)建好,為什么每次都要重復(fù)alter?
查看mysql相關(guān)表發(fā)現(xiàn)無外鍵,表引擎為MyISAM!此引擎不支持外鍵!
在使用hibernate自動(dòng)創(chuàng)建表時(shí),mysql中建表使用的MyISAM引擎,查看配置:

dialect:應(yīng)使用org.hibernate.dialect.MySQL5InnoDBDialect
這就解釋了:為什么orcle環(huán)境下沒有此問題,而mysql就有,其隨著時(shí)間的推移,表中數(shù)據(jù)逐漸增加,在啟動(dòng)時(shí)alter table耗時(shí)嚴(yán)重!
如何優(yōu)化SpringBoot的項(xiàng)目的啟動(dòng)速度
日常開發(fā)SpringBoot項(xiàng)目啟動(dòng)類都用@SpringBootApplication
實(shí)際上它是下面三個(gè)注解的組合
@EnableAutoConfiguration: enable Spring Boot's auto-configuration mechanism@ComponentScan: enable@Componentscan on the package where the application is located (see the best practices)@Configuration: allow to register extra beans in the context or import additional configuration classes
啟動(dòng)慢往往跟@ComponentScan和@EnableAutoConfiguration加載的內(nèi)容太多有關(guān),一種方法是不用這兩個(gè)注解,通過@import注解精確指定要加載掃描的類,但要加載的類多時(shí)又很麻煩,
可以用@SpringBootApplication注解下面的屬性
exclude: Exclude the list of classes from the auto configuration.excludeNames: Exclude the list of fully qualified class names from the auto configuration. This parameter added since spring boot 1.3.0.scanBasePackageClasses: Provide the list of classes that has to be applied for the @ComponentScan.scanBasePackagesProvide the list of packages that has to be applied for the @ComponentScan. This parameter added since spring boot 1.3.0.
另外,如果SpringBoot項(xiàng)目啟動(dòng)很慢,可能意味著你要重新拆分微服務(wù)。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
MyBatis-Plus?ORM數(shù)據(jù)庫和實(shí)體類映射方式
本文詳細(xì)介紹了MyBatis-Plus(MP)在數(shù)據(jù)庫和Java對象映射方面的功能,包括基本映射、主鍵生成策略、復(fù)雜映射(如嵌套對象和集合類型)以及自定義SQL的使用,MP通過豐富的注解和XML配置,簡化了數(shù)據(jù)庫操作,提高了開發(fā)效率2025-01-01
java 避免出現(xiàn)NullPointerException(空指針)的方法總結(jié)
這篇文章主要介紹了java 避免出現(xiàn)NullPointerException(空指針)的方法總結(jié)的相關(guān)資料,需要的朋友可以參考下2017-09-09
使用java API實(shí)現(xiàn)zip遞歸壓縮和解壓文件夾
這篇文章主要介紹了使用java API實(shí)現(xiàn)zip遞歸壓縮文件夾及解壓,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
Java?Stream實(shí)現(xiàn)多字段分組groupingBy操作詳解
Stream是Java8的一個(gè)新特性,主要用戶集合數(shù)據(jù)的處理,如排序、過濾、去重等等功能,本文就來講講如何利用Stream實(shí)現(xiàn)比較優(yōu)雅的按多字段進(jìn)行分組groupingBy吧2023-06-06
解讀靜態(tài)資源訪問static-locations和static-path-pattern
本文主要介紹了Spring Boot中靜態(tài)資源的配置和訪問方式,包括靜態(tài)資源的默認(rèn)前綴、默認(rèn)地址、目錄結(jié)構(gòu)、訪問路徑以及靜態(tài)資源處理器的工作原理,通過配置文件和實(shí)現(xiàn)`WebMvcConfigurer`接口,可以自定義靜態(tài)資源目錄和訪問前綴2025-01-01
Java實(shí)現(xiàn)DES加密與解密,md5加密以及Java實(shí)現(xiàn)MD5加密解密類
這篇文章主要介紹了Java實(shí)現(xiàn)DES加密與解密,md5加密以及Java實(shí)現(xiàn)MD5加密解密類 ,需要的朋友可以參考下2015-11-11
Spring Data環(huán)境搭建實(shí)現(xiàn)過程解析
這篇文章主要介紹了Spring Data環(huán)境搭建實(shí)現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08

