快速定位OOM

 

 

分析堆信息指标

堆信息
0
堆内存dump
没挂:
jmap -dump:format=b,file=xushu.hprof 14660
0
挂了:
也可以设置内存溢出自动导出dump文件(内存很大的时候,可能会导不出来)
  1. -XX:+HeapDumpOnOutOfMemoryError
  2. -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文件分析
0
 
 
底层其实就是封装的该命令:jmap -histo:live 18777 | more
posted @ 2023-09-13 10:45  up~up  阅读(19)  评论(0)    收藏  举报