今天看到監(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ù)就行。
