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.通过jhatdump文件进行分析

用法: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
 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值