java.lang.OutOfMemoryError: Java heap space 内存溢出问题排查

最近一直排查系统中的内存溢出问题。

不管是用jmap指令还是用比较直观的jvisualvm工具。都可以看到堆内存中各个对象的数量以及占用的内存大小。

一般只要找到有大量的自定义对象一直无法释放,那么距离定位到问题就不远了。

来看一个例子吧:

java.lang.OutOfMemoryError: Java heap space 内存溢出问题排查

就像图里看到的这样 一般都是这些对象数量巨大内存大部分也都是他们占用的。

今天明确了一个问题,这里统计的String对象指所有的String对象,包含在其他类中的属性。

比如我们自定义一个类 xxx 有10个String类型的属性,如果有10万个xxx对象,那么堆里就会多100万个String对象。(所有属性都必须是有值的而且是一个新的对象)。

而当我们看到自定义对象只占用内存的百分之几的时候,要知道对象如果属性很多的话,算是我们对象引用的所有对象。占用的总内存可能是非常大的。

如果某个线程执行时间过长,那么就很危险了。占用的内存无法释放。就容易造成内存的溢出。

如果自定义对象超过10万,就有内存溢出的危险了。

内存溢出的问题,首先看对象数会不会太多,如果太多可能 直接在创建过程中就溢出了。

其次,看线程的处理时间,如果能很快结束,内存就会很快释放。