最近碰到的一次內存溢出問題,記錄一下(只記錄正確找出問題的方法,其它的各種不提),也以此來重新開始自己的博客園之旅。
Tomcat打包發布后,一切OK,回歸測試也沒問題。但是運行一段時間后卻報內存溢出,服務器shutdown,重起數次失敗后直接停掉。
運維人員不在,拿不到堆棧日志,先對那段時間的人員操作日志結合catalina日志進行分析。發現開始出問題的時間,開始出現某一個頁面的操作,初步懷疑是這個頁面相關的代碼引起的;接著就看相關代碼提交日志,居然沒看出問題。后來找運維要到堆棧日志,問題還是定位到這里,在經驗更豐富的同事的幫助下,定位到以下代碼:
select id, other_id from tbl where 1=1
<if test="ids != null ">
and other_id in
<foreach item="item" index="index" collection="ids" open="(" separator="," close=")">
#{item}
</foreach>
</if>
如果ids==null,就會把整個表里的數據掃出來,而tbl表中的數據有1千多萬,直接把內存撐爆了。而最終的原因就是在調用方法前沒有對ids的list進行非空判斷。
總結:對于java的集合,使用之前盡量進行非空判斷,可以用CollectionUtils.isEmpty()方法;對于大表的sql語句,一定要檢驗所有if判斷條件都不成立時的查詢結果。
新聞熱點
疑難解答