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
![](https://img-blog.csdnimg.cn/20200822210003524.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTA2ODk4NDk=,size_16,color_FFFFFF,t_70)
可以看到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结果如下:
![](https://img-blog.csdnimg.cn/20200822211342626.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTA2ODk4NDk=,size_16,color_FFFFFF,t_70)
可以看到启动了一个端口为9999的服务。
浏览器输入ip端口号:
http://localhost:9999
![](https://img-blog.csdnimg.cn/20200822211558790.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTA2ODk4NDk=,size_16,color_FFFFFF,t_70)
可以看到对象是按包分类的,点击对象可以查看到具体信息。
在最后面有
OQL
查询功能,他是一个类似于sql语句的查询
![](https://img-blog.csdnimg.cn/20200822212043526.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTA2ODk4NDk=,size_16,color_FFFFFF,t_70)
点击进入如下:
![](https://img-blog.csdnimg.cn/20200822212227244.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTA2ODk4NDk=,size_16,color_FFFFFF,t_70)
使用方法可以点击OQLHelp查看。
![](https://img-blog.csdnimg.cn/20200822212343262.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTA2ODk4NDk=,size_16,color_FFFFFF,t_70)
如上select s from java.lang.String s where s.value.length >= 100的意思是查询字符串长度大于等于100的对象。
![](https://img-blog.csdnimg.cn/20200822212501739.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3UwMTA2ODk4NDk=,size_16,color_FFFFFF,t_70)
对于dump文件的分析也可以通过相关工具分析,例如基于eclipse的
MAT工具,基于idea的JProfiler