【JVM】Jmap+MAT实战内存溢出

这里写图片描述

导出内存映像文件

#第一种:内存溢出自动导出
-XX:+HeapDumpOnOutOfMemoryError
-XX:HeapDumpPath=./
#第二种:使用jmap命令手动导出
[root@localhost ~]# jmap -dump:format=b,file=heap.hprof 1092
Dumping heap to /root/heap.hprof ...
Heap dump file created

测试

    private List<User>  userList = new ArrayList<User>();
    private List<Class<?>>  classList = new ArrayList<Class<?>>();

    /**
     * -Xmx32M -Xms32M
     * */
    @GetMapping("/heap")
    public String heap() {
        int i=0;
        while(true) {
            userList.add(new User(i++, UUID.randomUUID().toString()));
        }
    }

启动时配置参数

-Xmx32M
-Xms32M
-XX:+HeapDumpOnOutOfMemoryError
-XX:HeapDumpPath=./

这里写图片描述

启动程序,访问:http://localhost:12345/heap

这里写图片描述

导出的文件

这里写图片描述

用eclipse打开上面文件

这里写图片描述

这里写图片描述

Shallow Heap:浅堆java对象占用的内存

Retained Heap:深堆java对象及对象引用的类占用的内存 ,jvm gc回收时释放的内存

Retained Heap深堆大于等于Shallow Heap浅堆,分析内存以深堆为主。

猜你喜欢

转载自blog.csdn.net/zlt995768025/article/details/81805254
今日推荐