首页 > 技术文章 > JAVA命令系列(三) : jmap

huyang0726 2022-02-27 21:48 原文

1、功能

jmap 主要用于打印指定java进程的堆内存信息。可以使用jmap生成Heap Dump,查看堆内存对象示例的统计信息、查看ClassLoader的信息

 2、位置

 jmap 命令位于$JAVA_HOME/bin目录下

 3、jmap 的用法

 参数:

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

option

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

3.1 no option 

命令: jmap pid

jmap pid 使用不带选项参数的jmap打印共享对象映射,会打印目标虚拟机中加载的每个共享对象的起始地址、映射大小以及共享对象文件的路径全称

 3.2 heap 

命令: jmap -heap pid

 打印一个堆的摘要信息,包括使用的GC算法、堆配置信息和各内存区域内存使用情况

 3.3 histo[:live]

命令: jmap -histo:live pid 

输出每个java类的对象数量、内存大小(单位:字节)、完全限定的类名。打印的虚拟机内部的类名称将会带有一个‘*‘’前缀。如果指定了live子选项,则只计算活动的对象

第一列:编号id

第二列:实例个数

第三列:所有实例大小

第四列:类名

 3.4 finalizerinfo

  命令: jmap -finalizerinfo pid

   打印等待终结的对象信息

 Number of objects pending for finalization: 0 说明当前F-QUEUE队列中并没有等待Fializer线程执行finalizer方法的对象。

3.5 dump:<dump-options>

命令 jmap -dump:live,format=b,file=dump.hprof pid

以hprof二进制格式转储Java堆到指定filename的文件中。live子选项是可选的。如果指定了live子选项,堆中只有活动的对象会被转储

 3.6 -F 

强制模式。如果指定的pid没有响应,请使用jmap -dump或jmap -histo选项。此模式下,不支持live子选项

jmap -F -dump:format=b,file=dump.hprof

 

推荐阅读