jmap的使用以及内存溢出分析
jmap命令主要作用是内存使用情况的汇总、对内存溢出的定位与分析。
1.查看内存使用情况
首先使用jps查找进程(这里启动了tomcat)
再输入命令 : jmap -heap 1940
Heap Configuration: 堆内存配置信息
Heap Usage: 堆内存的使用情况
PS Young Generation :年轻代
PS Old Generation :年老代
2.查看内存中对象数量及大小
2.1查看所有对象,包括活跃以及非活跃的:
jmap -histo | more
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
可以看到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.通过jhat对dump文件进行分析
用法:jhat -port <port> <file>
输入jhat -port 9999 C:\Users\cz215\Desktop\test\dump.dat结果如下:
可以看到启动了一个端口为9999的服务。
浏览器输入ip端口号:http://localhost:9999
可以看到对象是按包分类的,点击对象可以查看到具体信息。
在最后面有OQL查询功能,他是一个类似于sql语句的查询
点击进入如下:
使用方法可以点击OQLHelp查看。
如上select s from java.lang.String s where s.value.length >= 100的意思是查询字符串长度大于等于100的对象。
对于dump文件的分析也可以通过相关工具分析,例如基于eclipse的MAT工具,基于idea的JProfiler