jvm性能調優工具之jmap

jmap是JDK自帶的工具軟件,主要用於打印指定Java進程(或核心文件、遠程調試服務器)的共享對象內存映射或堆內存細節。可以使用jmap生成Heap Dump,map是一個多功能的命令。它可以生成 java 程序的 dump 文件, 也可以查看堆內對象示例的統計信息、查看 ClassLoader 的信息以及 finalizer 隊列。

jmap用法


jvm性能調優工具之jmap

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:<dump-options>:/<dump-options>生成堆轉儲快照
  • F: 當-dump沒有響應時,使用-dump或者-histo參數. 在這個模式下,live子參數無效.
  • help:打印幫助信息
  • J<flag>:/<flag>指定傳遞給運行jmap的JVM的參數

命令一:查看java 堆(heap)使用情況,執行命令:jmap -heap pid


jvm性能調優工具之jmap

顯示Java堆詳細信息

命令二:no option:jmap pid


jvm性能調優工具之jmap

no option

命令三:顯示堆中對象的統計信息 jmap -histo:live pid


jvm性能調優工具之jmap

顯示堆中對象的統計信息

命令四:打印類加載器信息,jmap -clstats pid

命令五:生成堆轉儲快照dump文件,jmap -dump:format=b,file=heapdump.phrof pid,

這個命令執行,JVM會將整個heap的信息dump寫入到一個文件,heap如果比較大的話,就會導致這個過程比較耗時,並且執行的過程中為了保證dump的信息是可靠的,所以會暫停應用, 線上系統慎用。


分享到:


相關文章: