一次工作中程序突然oom了导致内存居高不下,这里记录一下事情发生的过程和解决方法。
溢出场景:
当我在查询数据库一个大表并进行返回时,出现了内存溢出提示。
并且只从内存溢出后内存就一直居高不下,下面分别是内存溢出前服务器内存占用和溢出后内存的占用。可以看到溢出前服务器内存占用仅为34%,且程序运行没有很明显的卡涩。
但是内存溢出后服务器内存占用达到了89%,光光是Java程序就占了2G的内存,程序运行也很卡涩。
解决方法:
我首先使用了jvisualvm进行手动垃圾回收想降低一下内存占用。但是点击了多次垃圾回收后内存占用降低了10%,当时内存占用仍有79%,占用仍然很高。
于是最终我只能重启服务,并限定了该接口查询数据的条数,避免下次再出现oom的情况。