原博客:mp.weixin.qq.com/s?__biz=MzI…
-
内存中加载的数据量过于庞大,如一次从数据库取出过多数据。
-
集合类中有对对象的引用,使用完后未清空,使得JVM不能回收。
-
代码中存在死循环或循环产生过多重复的对象实体。
-
使用的第三方软件中的BUG。
-
启动参数内存值设定的过小。
解决: 重点排查以下几点:
检查代码中是否有死循环或递归调用。
检查是否有大循环重复产生新对象实体。
检查对数据库查询中,是否有一次获得全部数据的查询。一般来说,如果一次取十万条记录到内存,就可能引起内存溢出。这个问题比较隐蔽,在上线前,数据库中数据较少,不容易出问题,上线后,数据库中数据多了,一次查询就有可能引起内存溢出。因此对于数据库查询尽量采用分页的方式查询。
检查List、MAP等集合对象是否有使用完后,未清除的问题。List、MAP等集合对象会始终存有对对象的引用,使得这些对象不能被GC回收。
检查对大文件的读取是否采用类nio的方式。