jmap的使用以及内存溢出分析

jmap命令主要作用是内存使用情况的汇总、对内存溢出的定位与分析。
 
 

1.查看内存使用情况

首先使用jps查找进程(这里启动了tomcat)

再输入命令 :  jmap -heap 1940

jmap的使用以及内存溢出分析_第1张图片

Heap Configuration: 堆内存配置信息
Heap Usage: 堆内存的使用情况
PS Young Generation : 年轻代
PS Old Generation : 年老代
 

2.查看内存中对象数量及大小

2.1查看所有对象,包括活跃以及非活跃的:

jmap -histo | more

jmap的使用以及内存溢出分析_第2张图片

more后面输入空格可以查看更多对象。

对象说明:
B------------------------------ byte
C------------------------------ char
D------------------------------ double
F------------------------------ float
I-------------------------------- int
J------------------------------- long
Z------------------------------ boolean
[------------------------------- 数组,如[I 表示 int[]
[L+类名--------------------- 其他对象
 

2.2查看活跃对象:

查看活跃对象即在-histo后面添加live
 
jmap -histo:live | more
 
jmap的使用以及内存溢出分析_第3张图片
可以看到instances少很多
 

3.将内存使用情况dump到文件中

要将jvm当前内存中的情况dump到文件中,然后对它进行分析

用法:jmap -dump:format=b,file=dumpFileName

这里format=b意思是文件格式是一个二进制,file=dumpFileName为指定文件名。

输入如下命令:jmap -dump:format=b,file=C:\Users\cz215\Desktop\test\dump.dat 1940

结果如下:

查看C:\Users\cz215\Desktop\test\路径可以看到文件已经生成。

4.通过jhatdump文件进行分析

用法:jhat -port  
 
输入jhat -port 9999 C:\Users\cz215\Desktop\test\dump.dat结果如下:
 
jmap的使用以及内存溢出分析_第4张图片
可以看到启动了一个端口为9999的服务。
浏览器输入ip端口号: http://localhost:9999
jmap的使用以及内存溢出分析_第5张图片
可以看到对象是按包分类的,点击对象可以查看到具体信息。
 
在最后面有 OQL 查询功能,他是一个类似于sql语句的查询
jmap的使用以及内存溢出分析_第6张图片
 
点击进入如下:
jmap的使用以及内存溢出分析_第7张图片
使用方法可以点击OQLHelp查看。
 
jmap的使用以及内存溢出分析_第8张图片
如上select s from java.lang.String s where s.value.length >= 100的意思是查询字符串长度大于等于100的对象。
 
jmap的使用以及内存溢出分析_第9张图片
 
对于dump文件的分析也可以通过相关工具分析,例如基于eclipse的 MAT工具,基于idea的JProfiler
 

你可能感兴趣的:(Java)