Centos 啟動(dòng)Spring boot項(xiàng)目慢的原因

在客戶那部署 Springboot項(xiàng)目,啟動(dòng)非常慢要2-3分鐘. 因?yàn)殚_發(fā)的時(shí)候本地windows啟只要7s,測(cè)試環(huán)境也是centos只要7s.
因?yàn)榭蛻裟鞘翘摂M化了3臺(tái)機(jī)器, 安裝同樣的操作系統(tǒng),但其中1臺(tái)很快7s,其他兩臺(tái)很慢.這就非常奇怪了.
網(wǎng)上大部份都說(shuō)random的原因, 我們?nèi)颊罩牧艘廊缓苈?
通過(guò)strace確切知道改成功了,沒改之前全是random,改了之后有urandom.
但是可以發(fā)現(xiàn)還是會(huì)調(diào)random, 而且機(jī)器的隨機(jī)數(shù)值一直在3000左右,所以可以排除random原因.


image.png

奇怪的是系統(tǒng)也沒有報(bào)錯(cuò),就是啟動(dòng)慢,啟動(dòng)成功后接口頁(yè)面都沒有問題.關(guān)鍵是有1臺(tái)機(jī)器又很快,所以讓我們只能考慮是機(jī)器原因或虛擬化的原因.然后我們復(fù)制了一臺(tái)那個(gè)沒有問題的機(jī)器, 在這一臺(tái)上重新部署,結(jié)果依然是很慢.查看cpu 內(nèi)存 io 都沒有什么問題.
通過(guò)starce也只能看出是 futex 花費(fèi)了大量時(shí)間,下圖上11254這個(gè)進(jìn)程id,這個(gè)futex花費(fèi)了1.89s,然后往上找到11254的源頭也看不出什么原因?qū)е?


image.png
image.png

然后懷疑應(yīng)該不是我們項(xiàng)目問題,我拿一個(gè)最簡(jiǎn)單的springboot項(xiàng)目測(cè)試也是很慢.
然后把springboot日志級(jí)別調(diào)成debug, 剛開始查問題的時(shí)候就已經(jīng)試過(guò)了調(diào)日志,因?yàn)榘l(fā)現(xiàn)出現(xiàn)Spring那個(gè)logo之前很慢而且也沒有日志, 然后后面的日志又太長(zhǎng),以為找不出什么有用的信息,試過(guò)一次后就又調(diào)成info級(jí)別了.
我們啟動(dòng)慢的情況是這樣的,啟動(dòng)后, 等幾十秒出現(xiàn)Spring logo, 然后跑了一會(huì)兒,又等幾十秒,然后系統(tǒng)啟動(dòng)成功.
所以這一次想到,雖然啟動(dòng)前沒有日志,但是中間的慢,應(yīng)該可以知道它停在哪里.然后google那個(gè)停在那里的日志.


image.png

image.png

點(diǎn)進(jìn)去后有一句話看的我心頭一愣 , 這個(gè)用戶說(shuō),似乎這20s的等待是由于NetworkInterface.getAll
方法


image.png

image.png

我突然眼前一亮,趕緊看一下我用jstack輸出的文件,我用jstack輸出了三個(gè)文件
1剛啟動(dòng)的時(shí)候,2第二次卡頓的時(shí)候,3啟動(dòng)成功的時(shí)候
果然在第一個(gè)和第二個(gè)文件里都有因?yàn)檎{(diào)用網(wǎng)絡(luò)相關(guān)的接口,而第三個(gè)則沒有.
image.png

那么也就是說(shuō)根本原因就是 InetAddress.getLocalHost 導(dǎo)致很慢的原因了.
然后用那個(gè)最簡(jiǎn)單的Springboot項(xiàng)目調(diào)用一下這個(gè)方法,果然不出所料花了20s的時(shí)間.
找到根本原因隨便一搜就知道,是因?yàn)樵?etc/hosts 里并沒有加入當(dāng)前主機(jī)的名字,.
在正式環(huán)境下加入了主機(jī)名后果然快了.
那為什么有一臺(tái)很快了,因?yàn)槟且慌_(tái)是另一個(gè)同事裝了mq,他修改了這個(gè)hosts文件加了主機(jī)名.
然后復(fù)制這臺(tái)機(jī)器的時(shí)候會(huì)填一個(gè)新主機(jī)名,所以復(fù)制的那一臺(tái)機(jī)器也很慢.


image.png

最終解決掉了這個(gè)奇怪的問題,通過(guò)這一次經(jīng)歷,也學(xué)會(huì)了使用strace,jstack等調(diào)試工具,也有不少的收獲.

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末血淌,一起剝皮案震驚了整個(gè)濱河市猾愿,隨后出現(xiàn)的幾起案子赡译,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,265評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡犹菇,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門芽卿,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)揭芍,“玉大人,你說(shuō)我怎么就攤上這事卸例〕蒲睿” “怎么了?”我有些...
    開封第一講書人閱讀 156,852評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵筷转,是天一觀的道長(zhǎng)姑原。 經(jīng)常有香客問我,道長(zhǎng)呜舒,這世上最難降的妖魔是什么锭汛? 我笑而不...
    開封第一講書人閱讀 56,408評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮袭蝗,結(jié)果婚禮上唤殴,老公的妹妹穿的比我還像新娘。我一直安慰自己到腥,他們只是感情好朵逝,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,445評(píng)論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著乡范,像睡著了一般配名。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上篓足,一...
    開封第一講書人閱讀 49,772評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音闰蚕,去河邊找鬼栈拖。 笑死,一個(gè)胖子當(dāng)著我的面吹牛没陡,可吹牛的內(nèi)容都是我干的涩哟。 我是一名探鬼主播索赏,決...
    沈念sama閱讀 38,921評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼贴彼!你這毒婦竟也來(lái)了潜腻?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,688評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤器仗,失蹤者是張志新(化名)和其女友劉穎融涣,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體精钮,經(jīng)...
    沈念sama閱讀 44,130評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡威鹿,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,467評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了轨香。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片忽你。...
    茶點(diǎn)故事閱讀 38,617評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖臂容,靈堂內(nèi)的尸體忽然破棺而出科雳,到底是詐尸還是另有隱情,我是刑警寧澤脓杉,帶...
    沈念sama閱讀 34,276評(píng)論 4 329
  • 正文 年R本政府宣布糟秘,位于F島的核電站,受9級(jí)特大地震影響丽已,放射性物質(zhì)發(fā)生泄漏蚌堵。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,882評(píng)論 3 312
  • 文/蒙蒙 一沛婴、第九天 我趴在偏房一處隱蔽的房頂上張望吼畏。 院中可真熱鬧,春花似錦嘁灯、人聲如沸泻蚊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)性雄。三九已至,卻和暖如春羹奉,著一層夾襖步出監(jiān)牢的瞬間秒旋,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工诀拭, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留迁筛,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,315評(píng)論 2 360
  • 正文 我出身青樓耕挨,卻偏偏與公主長(zhǎng)得像细卧,于是被迫代替她去往敵國(guó)和親尉桩。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,486評(píng)論 2 348