一.先安装必要的工具和环境
1.jmap只要jdk正常安装就默认就有,
2.MAT安装,个人一般使用独立插件的形式安装,下载地址: http://www.eclipse.org/mat 安装方式请自行查找
二.生成堆栈文件并下载到本地
1.进入线上环境,使用jmap生成堆栈文件,其中查看jmap的路径命令:which jmap
查看对应的java服务进程命令:jps -v|grep server_name
生成堆栈文件:jmap -dump:live,format=b,file=./jmap/map.bin 20874,目录就是./jmap/map.bin
2.通过sz命令或者类Xftp工具把map.bin文件烤到本地。
三.利用MAT分析map.bin文件
通过MAT中的File-》Open Heap Dump... 打开map.bin文件,接下来就可以分析内存溢出原因了。
四.MAT中的两个关键字:Shallow Heap,Retained Heap
Shallow Size
对象自身占用的内存大小,不包括它引用的对象。
针对非数组类型的对象,它的大小就是对象与它所有的成员变量大小的总和。当然这里面还会包括一些java语言特性的数据存储单元。
针对数组类型的对象,它的大小是数组元素对象的大小总和。
Retained Size=当前对象大小+当前对象可直接或间接引用到的对象的大小总和。(间接引用的含义:A->B->C, C就是间接引用)
换句话说,Retained Size就是当前对象被GC后,从Heap上总共能释放掉的内存。
不过,释放的时候还要排除被GC Roots直接或间接引用的对象。他们暂时不会被被当做Garbage
jmap的一些命令
- jmap pid #打印内存使用的摘要信息
- jmap –heap pid #java heap信息
- jmap -histo:live pid #统计对象count ,live表示在使用
- jmap -histo pid >mem.txt #打印比较简单的各个有多少个对象占了多少内存的信息,一般重定向的文件
- jmap -dump:format=b,file=mem.dat pid #将内存使用的详细情况输出到mem.dat 文件