今天看到監(jiān)控平臺顯示項目的Full GC次數(shù)過多鹏浅,查看了一下監(jiān)控曲線,如下圖钳宪,發(fā)現(xiàn)發(fā)生的時間點基本上都是在上午十點之后揭北,到下午五點扳炬。
分析:考慮到業(yè)務(wù)形態(tài),開始初步懷疑是訪問人數(shù)增多引起的虛擬機內(nèi)存不足搔体,后來繼續(xù)看監(jiān)控指標(biāo)找線索恨樟,發(fā)現(xiàn)如下圖的監(jiān)控曲線,當(dāng)Young GC時疚俱,Old區(qū)的已使用空間并沒有發(fā)生明顯變化劝术,而且剩余空間也非常大,所以通過這個分析發(fā)生Full GC的原因并不是虛擬機自動回收內(nèi)存導(dǎo)致呆奕,很可能是在代碼中存在System.gc()养晋,所導(dǎo)致的Full GC。
?在項目中搜索梁钾,發(fā)現(xiàn)jxl.jar中存在System.gc代碼绳泉,這個jar的使用跟項目中需要進行Excel操作的需求有關(guān),逐級跟蹤到調(diào)用接口姆泻,找到調(diào)用接口之后零酪,在監(jiān)控平臺上查看此接口的訪問情況,發(fā)現(xiàn)確實是在發(fā)生Full GC時的時間點與接口訪問的時間點相同麦射,也就印證了我們的猜測蛾娶。
解決:找到了問題之后,解決起來就相對簡單了潜秋,經(jīng)過查看源碼發(fā)現(xiàn)蛔琅,初始化Excel操作類時提供了兩個構(gòu)造函數(shù),一般都是使用默認的峻呛,這次我們只需要把相關(guān)的配置參數(shù)傳給構(gòu)造函數(shù)就行罗售。