快速定位OOM

分析堆信息指标
堆信息
堆内存dump
没挂:
jmap -dump:format=b,file=xushu.hprof 14660
挂了:
也可以设置内存溢出自动导出dump文件(内存很大的时候,可能会导不出来)
- -XX:+HeapDumpOnOutOfMemoryError
- -XX:HeapDumpPath=./ (路径)
java -Xms10M -Xmx10M -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=./java_logs -jar jvm-demo.jar
示例代码:
public class OOMTest { public static List<Object> list = new ArrayList<>(); // JVM设置 // -Xms10M -Xmx10M -XX:+PrintGCDetails -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\jvm.dump public static void main(String[] args) { List<Object> list = new ArrayList<>(); int i = 0; int j = 0; while (true) { list.add(new User(i++, UUID.randomUUID().toString())); new User(j--, UUID.randomUUID().toString()); } } }
可以用jvisualvm命令工具导入该dump文件分析
底层其实就是封装的该命令:jmap -histo:live 18777 | more
本文来自博客园,作者:up~up,转载请注明原文链接:https://www.cnblogs.com/soft-engineer/articles/17698931.html
浙公网安备 33010602011771号