VisualVM是一个目前最为流行的可视化的Java性能分析和优化工具,免费开源,拥有多强大的java应用程序分析能力,包括内存分析、CPU分析、线程分析、快照分析、转存储生成与分析等功能,帮助开发者更好地对 Java 应用程序做性能分析和调优。
注意:JDK1.8_361及以上版本需去官网安装下载,官网:http://visualvm.github.io
一、堆内存OOM(heap space)
堆内存OOM是最为常见的OOM之一,主要原因有两个:
1、代码中可能存在大对象
2、可能存在内存泄露,导致在多次GC之后,还是无法找到一块足够大的内存容纳当前对象
报错信息如下:
java.lang.OutOfMemoryError: Java heap space
代码示例:
public class OOMTest {
public static void main(String[] args) throws InterruptedException {
List<User> users = new ArrayList<>();
int userDataSize = 1024 * 1024 * 100;
while (true) {
users.add(new User(userDataSize));
Thread.sleep(1000);
}
}
}
执行结果:
VisualVM分析:可以看到当前堆内存大小为Size,已经超过Max值,未使用的堆内存已经不满足继续执行,出现了上面堆内存OOM问题