分析堆信息指标

堆信息

堆内存 dump

没挂:

jmap -dump:format=b,file=xushu.hprof 14660

挂了:

也可以设置内存溢出自动导出 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 文件分析

底层其实就是封装的该命令:jmap -histo:live 18777 | more