jmap工具的使用

jmap可用作java内存的分析工具,主要命令格式如下(以下pid指的是进程id):
    1、jmap  【参数】 pid             
参数列表
heap : 显示Java堆的相关信息
histo : 显示堆中对象的统计信息
permstat : Java堆内存的永久保存区域的类加载器的统计信息
finalizerinfo : 显示在F-Queue队列等待Finalizer线程执行finalizer方法的对象
dump : 生成堆转储快照
F : 当-dump没有响应时,强制生成dump快照

jmap -heap 1654 可显示java内存信息、垃圾收集器的信息

jmap -dump:live,format=b,file=dump.hprof 49105

jmap -histo:live 24971 |more  

 jmap -permstat 49105

下面实例演示

1、 jmap -heap 1654 可显示java内存信息、垃圾收集器的信息

2、生成堆文件
    命令 jmap -dump:live,format=b,file=dump.hprof 49105 -dump生成命令 live:只选择活着的对象 format:格式 file:文件保存路径
3、查看待回收的信息
命令 jmap -finalizerinfo 49105 Number of objects pending for finalization: 0 待回收的数量为0


4、查看堆中对象的信息        jmap -histo:live 24971 |more  
      jmap -histo:live 24971 | grep                          grep可以过滤想要看的信息
    如图   instances:实例数量  bytes:大小   classname:类名

5、打印类加载器的信息
     jmap -permstat 49105




使用jmap工具可以对Java应用程序进行内存分析,帮助排查OOM问题。以下是使用jmap工具进行OOM排查的步骤: 1. 确认OOM错误:通过查看应用程序的日志或系统日志,确认是否发生了OOM错误。 2. 获取Java进程ID:使用`jps`命令获取Java进程的ID,例如:`jps -l`。 3. 使用jmap生成堆转储文件:运行以下命令生成堆转储文件(heap dump file): ``` jmap -dump:format=b,file=heapdump.bin <pid> ``` 其中,`<pid>`是Java进程的ID。 4. 分析堆转储文件:使用MAT(Memory Analyzer Tool)等内存分析工具来打开生成的堆转储文件。MAT是一款常用的Java堆内存分析工具,可以下载安装并打开生成的堆转储文件。 5. 查找内存泄漏:在MAT中,可以通过执行一系列分析操作来查找可能的内存泄漏。其中一种常用的分析是通过查看堆转储文件中的对象引用关系来定位可能导致内存泄漏的对象。 6. 分析对象占用内存情况:在MAT中,可以查看对象占用内存的情况,包括对象数量、大小和引用关系等信息。这有助于确定哪些对象占用了大量内存,可能导致OOM。 7. 优化代码和资源释放:根据分析结果,优化代码以避免内存泄漏或者减少内存占用。确保及时释放不再需要的对象和资源,使用合适的数据结构等。 请注意,使用jmap生成堆转储文件会在运行期间暂停Java进程一段时间,请在生产环境中谨慎使用。此外,内存分析工具使用需要一定的经验和技巧,对于复杂的问题,建议咨询专业的开发人员来进行排查和解决。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值