溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

springboot程序啟動慢未配置hostname的解決方法

發(fā)布時間:2021-08-30 20:49:05 來源:億速云 閱讀:558 作者:chen 欄目:開發(fā)技術(shù)

這篇文章主要介紹“springboot程序啟動慢未配置hostname的解決方法”,在日常操作中,相信很多人在springboot程序啟動慢未配置hostname的解決方法問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”springboot程序啟動慢未配置hostname的解決方法”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

目錄
  • springboot程序啟動慢-未配置hostname

    • 具體日志如下

    • 通過jstack查看線程發(fā)現(xiàn)如下信息

    • 查看源碼如下

  • Spring Boot啟動速度慢的原因總結(jié)

    • 前提條件

    • 原因一

    • 原因二

    • 原因三

    • 解決方法

springboot程序啟動慢-未配置hostname

今天有同時反饋自己的程序在本地mac環(huán)境還正常,在生產(chǎn)環(huán)境上centos7啟動特別慢

具體日志如下

springboot程序啟動慢未配置hostname的解決方法

可以看到程序在這里卡了將近2分鐘時間,期間無任何日志輸出。

通過jstack查看線程發(fā)現(xiàn)如下信息

springboot程序啟動慢未配置hostname的解決方法

查看源碼如下

public native InetAddress[] lookupAllHostAddr(String hostname) throws UnknownHostException;

入?yún)閔ostname,于是查看機器hostname,再ping hostname發(fā)現(xiàn)ping不通,至此知道解決辦法應(yīng)該是在/etc/hosts配置一下hostname為本機ip即可解決。

配置hostname后程序正常啟動了。

Spring Boot啟動速度慢的原因總結(jié)

現(xiàn)在spring boot的架構(gòu)可以說是非常流行,不會你都不好意思說你是做java的??墒撬饸w火,也有一些小問題需要咱們?nèi)プ⒁狻?/p>

如果是單體項目,并且在啟動速度方面沒有任何要求,那么請忽略。

下面進(jìn)入主題,在什么情況下spring boot的項目啟動會變慢呢

前提條件

啟動項目的機器硬件配置不能拖后腿,否則你說項目啟動慢,項目還覺得機器不行呢…

比如網(wǎng)絡(luò),內(nèi)存大小,CPU核心數(shù)等,不要求太高,至少也要夠用吧

拋開各種人為因素,例如各種連接時間較長,其他組件啟動較慢導(dǎo)致等待…

原因一

項目中使用的無用配置太多。

例如在一個最簡單的web中,你還加入了其他各種maven配置,并且將他們配置到項目中(只是比較夸張的例子,這些配置加入都不用),然后項目本身也不懂,既然你配置了,那就加載唄。一個花0.1秒,10個就1秒,100個就10秒了…以此類推,這一點就是最容易想明白的地方了。

原因二

spring boot的自動配置。

自動配置是spring boot的一個特色,但是也是它啟動慢的一個弊病。沒辦法,通常好用功能全的東西,總會在一些地方上有缺陷。上面說到無用的配置多,這里要說的就是spring boot它自己裝配的東西太多。你可以看到在spring boot的相關(guān)jar包里,都存放著spring.factories的文件,進(jìn)去一看,大部分都是寫了很多的類,它是實現(xiàn)spring boot自動裝配的核心之一。但是你仔細(xì)觀察會發(fā)現(xiàn),其實有很多類,你可能完全不用。但有什么辦法呢,不管你用不用,至少它都會給你檢查一遍,這不也是花時間的地方嗎?

原因三

項目精簡程度不夠。

現(xiàn)在比較流行微服務(wù)的概念,我認(rèn)為它的概念核心含義即為精簡,單一,并且多數(shù)需要強調(diào)啟動速度的地方也多是出自微服務(wù)的項目中。一個微服務(wù)項目中,最好是在10秒以內(nèi)能夠啟動完畢。但是多數(shù)是做不到的,原因在于項目拆分的還不夠細(xì)。你說一個接口啟動快,還是10個快,或是更多,答案很明顯。很多項目做到了大而全,所謂大而全就是功能很多,配置很齊全,各種可以擴展配置等,全面的不行不行的,但這意味著什么,你的配置多,有用沒用先不管,至少需要編譯和加載的類文件都會多出很多來,你說要這樣的項目能啟動快,怎么能啟動快呢?

解決方法

  • 檢查maven中是否無用的依賴太多

  • 比較復(fù)雜,使用spring-boot-maven插件debug啟動,查看該項目中,使用了哪些配置,哪些配置沒用,然后在啟動類中直接注明只啟動使用了的類,并且刪掉@SpringBootApplication注解,手動填上@Configuration和@Import注解,并在@Import注解中加上那些配置的類。

  • 更換一些配置更快的依賴。例如,你使用A數(shù)據(jù)庫連接池,功能全,配置多,但速度較慢,但是其實B連接池也能滿足項目需求,但是功能相對較少,所以配置也少,啟動更快,你是不是需要考A和B應(yīng)該選一個。

  • 拆分出更精簡的項目來獨自運行,大而全意味著多而不精,精而簡意味著少但是精通,它們速度,不言而喻。

到此,關(guān)于“springboot程序啟動慢未配置hostname的解決方法”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI