jmap命令详解

本文详细介绍了JVM的命令工具jmap的使用,包括查看内存映像、堆信息、对象统计、类加载器状态以及堆内存快照的生成。通过实例演示了如何利用jmap获取堆内存的详细信息、统计对象数量、查找内存占用大户以及分析等待回收的对象。这些信息对于诊断JVM内存问题和优化性能至关重要。

JVM常见命令之jmap

jmap命令详解

jmap是一个很重要的命令,可以查看JVM内存使用情况。jmap帮助文档
在这里插入图片描述
参数解释:

option: 选项参数。

  • pid: 需要打印配置信息的进程ID。
  • executable: 产生核心dump的Java可执行文件。
  • core:需要打印配置信息的核心文件。
  • server-id 可选的唯一id,如果相同的远程主机上运行了多台调试服务器,用此选项参数标识服务器。
    remote server IP or hostname 远程调试服务器的IP地址或主机名。

option解释

  • no option: 查看进程的内存映像信息,类似 Solaris pmap 命令。
  • heap: 显示Java堆详细信息
  • histo[:live]: 显示堆中对象的统计信息
  • clstats:打印类加载器信息
  • finalizerinfo: 显示在F-Queue队列等待Finalizer线程执行finalizer方法的对象
  • dump::生成堆转储快照
  • F: 当-dump没有响应时,使用-dump或者-histo参数. 在这个模式下,live子参数无效.
  • help:打印帮助信息
  • J:指定传递给运行jmap的JVM的参数

1、jmap pid 查看进程的内存映像信息
在这里插入图片描述

1、获取堆的配置及JVM堆内存的使用情况,包括堆内存大小,新生代、老年代、元空间等
jmap -heap 进程id

在这里插入图片描述

2、获取每个class的实例数目,字节数,类全名信息。如果live子参数加上后,只统计活的对象数量。
jmap -histo:live 进程id


在这里插入图片描述

查看对象数最多的对象,并按降序排序输出:
jmap -histo <pid>|grep alibaba|sort -k 2 -g -r|less

查看占用内存最多的最象,并按降序排序输出:
jmap -histo <pid>|grep alibaba|sort -k 3 -g -r|less


3、获取正等候回收的对象的信息
jmap -finalizerinfo 进程id


4、查看堆内存快照,输出jvm的heap内容到文件, live子选项是可选的,假如指定live选项,那么只输出活的对象到文件
jmap -dump:live,format=b,file=myjmapfile.txt 进程id

5、-clstats是-permstat的替代方案,在JDK8之前,-permstat用来打印类加载器的数据
打印Java堆内存的永久保存区域的类加载器的智能统计信息。对于每个类加载器而言,它的名称、活跃度、地址、父类加载器、它所加载的类的数量和大小都会被打印。此外,包含的字符串数量和大小也会被打印。

jmap -clstats 进程id

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值