記一次Full GC問題的排查

今天看到監(jiān)控平臺顯示項目的Full GC次數(shù)過多,查看了一下監(jiān)控曲線,如下圖,發(fā)現(xiàn)發(fā)生的時間點基本上都是在上午十點之后,到下午五點。


分析:考慮到業(yè)務(wù)形態(tài),開始初步懷疑是訪問人數(shù)增多引起的虛擬機(jī)內(nèi)存不足,后來繼續(xù)看監(jiān)控指標(biāo)找線索,發(fā)現(xiàn)如下圖的監(jiān)控曲線,當(dāng)Young GC時,Old區(qū)的已使用空間并沒有發(fā)生明顯變化,而且剩余空間也非常大,所以通過這個分析發(fā)生Full GC的原因并不是虛擬機(jī)自動回收內(nèi)存導(dǎo)致,很可能是在代碼中存在System.gc(),所導(dǎo)致的Full GC。

?在項目中搜索,發(fā)現(xiàn)jxl.jar中存在System.gc代碼,這個jar的使用跟項目中需要進(jìn)行Excel操作的需求有關(guān),逐級跟蹤到調(diào)用接口,找到調(diào)用接口之后,在監(jiān)控平臺上查看此接口的訪問情況,發(fā)現(xiàn)確實是在發(fā)生Full GC時的時間點與接口訪問的時間點相同,也就印證了我們的猜測。


解決:找到了問題之后,解決起來就相對簡單了,經(jīng)過查看源碼發(fā)現(xiàn),初始化Excel操作類時提供了兩個構(gòu)造函數(shù),一般都是使用默認(rèn)的,這次我們只需要把相關(guān)的配置參數(shù)傳給構(gòu)造函數(shù)就行。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 作者:一字馬胡 轉(zhuǎn)載標(biāo)志 【2017-11-12】 更新日志 日期更新內(nèi)容備注 2017-11-12新建文章初版 ...
    beneke閱讀 2,328評論 0 7
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,564評論 19 139
  • 1.什么是垃圾回收? 垃圾回收(Garbage Collection)是Java虛擬機(jī)(JVM)垃圾回收器提供...
    簡欲明心閱讀 90,372評論 17 311
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,048評論 25 709
  • 小明告訴我,昨天為了給兒子報培訓(xùn)班的事情,夫妻倆又開戰(zhàn)了。 小明老婆說,兒子班上的那些同學(xué),家長們都在給孩子...
    蘇州的薔薇花開閱讀 445評論 5 3

友情鏈接更多精彩內(nèi)容