JVM性能调优工具2之jcmd详解

转载自:

JVM性能调优工具2之jcmd详解(覆盖全网最全的jcmd命令与说明文档)-CSDN博客

上篇文章里《JVM常用性能调优工具详解1》我们已经探究了jps、jstat等监控工具,以及jinfo、jmap、jstack、jhat等故障排查工具,这里我单独拿出一篇文章,特别介绍jcmd。(因为jcmd这玩意细节太多了,整理文档就整理了好几个小时…)

jcmd
jcmd全称JVM Command,用于将诊断命令请求发送到正在运行的Java虚拟机,从JDK 7开始提供。

使用说明
命令如下:

-f				从文件读取并执行命令
-l				列出本机上的所有JVM进程

 我们先来看一下最简单的jcmd -l
可以查看当前正在运行的所有JVM进程,和jps有点类似

jcmd -h可以查看jcmd的帮助文档。

再来看一下jcmd <pid | main class> <command ...| PerfCounter.print | -f file>
这个命令

参数说明:

  • pid:接受诊断命令请求的进程ID。
  • main class:接受诊断命令请求的进程main类。jcmd会将诊断命令请求发送给指定main class的所有Java进程。
  • command:command必须是一个有效的jcmd命令,可以使用jcmd pid help命令查看可用的命令列表。如果pid是0,那么command将会被发送给所有Java进程。main class会用来去匹配(局部匹配或全量匹配)。如果未指定任何选项,他将会列出正在运行的Java进程标识符以及用于启动该进程的main class和命令参数(相当于使用了-l参数)
  • PerfCounter.print:打印指定Java进程上可用的性能计数器。
  • -f filename:从指定文件中读取命令并执行。在file中,每个命令必须写在单独的一行。以“#”开头的行会被忽略。当所有行的命令被调用完毕后,或者读取到含有stop关键字的命令,将会终止对file的处理。
  • -l:查看所有JVM进程。jcmd不使用参数与jcmd -l效果相同。

我们先用PerfCounter.print玩一下:

这样我们就能看到12735这个进程的性能计数器

我们换种玩法
先用jps -l获取启动类。

然后用jcmd跟上启动类:

可以发现也能正常获取结果。
当然最主要的还是另一种复杂的玩法,就是跟命令的形式。
那么jcmd有哪些命令呢?

下面我总结出了全网最全的jcmd的命令以及使用说明。整理这篇命令手记花费了作者大量的精力,可以说是全网无出其右,建议小伙伴们保存下来,方便后续查看。

支持的命令
1.help [options] [arguments]

  • 作用:查看指定命令的帮助信息
  • arguments:想查看帮助的命令(STRING,无默认值)
  • options:选项,必须使用key或者key=value的语法指定,可用的options如下:
    • -all:(可选)查看所有命令的帮助信息(BOOLEAN,false)

使用示例:

# 获得指定进程可用的命令列表
jcmd <pid> help
# 获取指定进程、指定命令的帮助信息,如果参数包含空格,需要用 ' 或者 " 引起来
jcmd <pid> help <command>

2.Compiler.codecache

  • 作用:打印code cache(代码缓存)的布局和边界
  • 影响:低
  • 所需权限:java.lang.management.ManagementPermission(monitor)

3.Complier.codelist

  • 作用:打印代码缓存中所有人在运行的已编译方法
  • 影响:中
  • 所需权限:java.lang.management.ManagementPermission(monitor)

4.Compiler.queue

  • 作用:打印排队等待编译的方法
  • 影响:低
  • 所需权限:java.lang.management.ManagementPermission(monitor)

5.Compiler.directives_add filename arguments

  • 作用:从文件添加编译器指令
  • 影响:低
  • 所需权限:java.lang.management.ManagementPermission(monitor)
  • filename:指令文件的名称(STRING,无默认值)

6.Compiler.directives_clear

  • 作用:删除所有编译器指令
  • 影响:低
  • 所需权限:java.lang.management.ManagementPermission(monitor)

7.Compiler.directives_print

  • 作用:打印所有活动的编译器指令
  • 影响:低
  • 所需权限:java.lang.management.ManagementPermission(monitor)

8.Compiler.directives_remove

  • 作用:删除最新添加的编译器指令。
  • 影响:低
  • 所需权限:java.lang.management.ManagementPermission(monitor)

9.GC.class_histogram [options]

  • 作用:提供有关Java堆使用情况的统计信息
  • 影响:高 (取决于Java堆的大小和内容)
  • 所需权限:java.lang.management.ManagementPermission(monitor)
  • options:选项,必须使用key或者key=value的语法指定,可用的options如下:
    • -all:(可选)检查所有对象,包括不可达的对象(BOOLEAN,false)

10.GC.class_stats [options] [arguments]

  • 作用:展示有关Java类元数据的统计信息
  • 影响:高(取决于Java堆的大小和内容)
  • options:选项,必须使用key或者key=value的语法指定,可用的options如下:
    • -all:(可选)显示所有列(BOOLEAN,false)
    • -csv:(可选)以CSV格式打印电子表格(BOOLEAN,false)
    • help:(可选)显示所有列的含义(BOOLEAN,false)
  • arguments:参数,可选参数如下:
    • columns:(可选)要显示的列,以逗号分隔。如果不指定,则显示以下列:
      • InstBytes
      • KlassBytes
      • CpAll
      • annotations
      • MethodCount
      • Bytecodes
      • MethodAll
      • ROAll
      • RWAll
      • Total

使用示例:

# 展示指定进程类的元数据的所有统计信息
jcmd 12737 GC.class_stats -all

# InstBytes、KlassBytes等列的含义
jcmd 12737 GC.class_stats -help

# 显示InstBytes,KlassBytes这两列,并生成csv
jcmd 12737 GC.class_stats -cvs InstBytes,KlassBytes > t.csv

11. GC.finalizer_info

  • 作用:展示有关Java finalization queue的信息
  • 影响:中
  • 所需权限:java.lang.management.ManagementPermission(monitor)

12. GC.heap_dump [options][arguments]

  • 作用:生成Java堆Dump文件(HPROF格式)
  • 影响:高(取决于Java堆大小和内容。除非指定了-all选项,否则会导致Full GC
  • 所需权限:java.lang.management.ManagementPermission(monitor)
  • options:选项,必须使用key或者key=value的语法指定,可用的options如下:
    • -all:(可选)转储所有对象,包括不可达对象(BOOLEAN,false)
  • arguments:参数,可用的参数如下:
    • filename:Dump文件的名称(STRING,无默认值)

使用示例:

jcmd 12737 GC.heap_dump -all 1.hprof

13. GC.heap_info

  • 作用:展示Java堆信息
  • 影响:中
  • 所需权限:java.lang.management.ManagementPermission(monitor)

14. GC.run

  • 作用:调用java.lang.System.gc()
  • 影响:中(取决于Java堆的大小和内容)

15.GC.run_finalization

  • 作用:java.lang.System.runFianlization()
  • 影响:中(取决于Java内容)

16.JFR.check [options]
请参考《Java Flight Recorder命令参考》中的JFR.check

17.JFR.configure [options]
请参考《Java Flight Recorder命令参考》中的JFR.configure

18.JFR.dump [options]
请参考《Java Flight Recorder命令参考》中的JFR.dump

19.JFR.start [options]
请参考《Java Flight Recorder命令参考》中的JFR.start

20.JFR.stop [options]
请参考《Java Flight Recorder命令参考》中的JFR.stop

21.JVMTI.agent_load [arguments]

  • 作用:加载JVMTI本机代理。
  • 影响:低
  • 所需权限:java.lang.management.ManagementPermission(control)
  • arguments:
    • library path:要加载的JVMTI代理的绝对路径(STRING,无默认值)
    • agent option:(可选)用于传递代理的选项字符串(STRING,无默认值)

22. JVMMTI.data_dump

  • 作用:通知JVM堆JVMTI进行数据转储
  • 影响:高
  • 所需权限:java.lang.management.ManagementPermission(monitor)

23. ManagentAgent.start [options]

  • 作用:启动远程管理代理
  • 影响:低
  • option:选项,必须使用key或者key=value的语法指定,可用的options如下:
    • config.file:(可选)设置com.sun.management.config.file(STRING,无默认值)
    • jmxremote.host:(可选)设置com.sun.management.jmxremote.host(STRING,无默认值)
    • jmxremote.port:(可选)设置com.sun.management.jmxremote.port(STRING,无默认值)
    • jmxremote.rmi.port:(可选)设置com.sun.management.jmxremote.rmi.port(STRING,无默认值)
    • jmxremote.ssl:(可选)设置com.sun.management.jmxremote.ssl(STRING,无默认值)
    • jmxremote.registry.ssl:(可选)设置com.sun.management.jmxremote.registry.ssl(STRING,无默认值)
    • jmxremote.authenticate:(可选)设置com.sun.management.jmxremote.authenticate(STRING,无默认值)
    • jmxremote.password.file:(可选)设置 com.sun.management.password.file(STRING,无默认值)
    • jmxremote.acccess.file:(可选)设置com.sun.management.jmxremote.access.file (STRING,无默认值)
    • jmxremote.login.config:(可选)设置com.sun.management.jmxremote.login.config(STRING,无默认值)
    • jmxremote.ssl.enabled.cipher.suites:(可选)集com.sun.management。
    • jmxremote.ssl.enabled.cipher.suite:(STIRNG,无默认值)
    • jmxremote.ssl.enabled.protocols:(可选)设置com.sun.management.jmxremote.ssl.enabled.protocols(STRING,无默认值)
    • jmxremote.ssl.need.client.auth:(可选)设置com.sun.management.jmxremote.need.client.auth(STRING,无默认值)
    • jmxremote.ssl.config.file:(可选)设置com.sun.management.jmxremote.ssl_config_file(STRING,无默认值)
    • jmxremote.autodiscovery:(可选)设置com.sun.management.jmxremote.autodiscoery(STRING,无默认值)
    • jdp.port:(可选)设置com.sun.management.jdp.port(INT,无默认值)
    • jdp.address:(可选)设置com.sun.management.jpdaddress(STRING,无默认值)
    • jdp.source_addr:(可选)设置com.sun.management.jdp.sourcce_addr(STRING,无默认值)
    • jdp.pause:设置com.sun.management.jdp.pause(INT,无默认值)
    • jdp.name:(可选)设置com.sun.management.jdp.name(STRING,默认值)

24. ManagementAgent.start_local

  • 作用:启动本地管理代理
  • 影响:低

25.ManagementAgent.status

  • 作用:展示管理代理的状态
  • 影响:低
  • 所需权限:java.lang.mangement.ManagementPermission(monitor)

26.Management.Agent.stop

  • 作用:停止远程管理代理
  • 影响:低

27.Thread.print [options]

  • 作用:打印所有带有堆栈跟踪的线程
  • 影响:中(取决于线程数)
  • 所需权限:java.lang.management.ManagementPermission(monitor)
  • options:选项,必须使用key或者key=value的语法指定,可用的options如下:
    • -l:(可选)打印java.util.concurrent锁(BOLEAN,false)

使用示例:

jcmd 12737 Thread.print -l

28.VM.check_commercial_features

  • 作用:显示商业特性的状态
  • 影响:低

29. VM.unlock_commercial_features

  • 作用:解锁商业功能
  • 影响:低
  • 所需权限:java.lang.management.ManagementPermission(control)

30. VM.classloader_stats

  • 作用:打印所有ClassLoader的统计信息。
  • 影响:低
  • 所需权限:java.lang.management.ManagementPermission(monitor)

31. VM.class_hierarchy [options] [arguments]

  • 作用:打印所有已加载的列表,缩进以显示类层次结构。每个类的名称后跟其ClassLoader的ClassLoaderData*,如果有bootstrap class loader加载,则为null
  • 影响:中(取决于已加载类的数量)
  • 所需权限:java.lang.management.ManagementPermission(monitor)
  • options:选项,必须使用key或者key=value的语法指定,可用的options如下:
    • -i:(可选)打印继承的接口(BOOLEAN,false)
    • -s:(可选)如果指定了类名,则将打印子类。如果未指定类名则打印超类(BOOLEAN,false)
  • arguments:参数,可用选项如下:
    • classname:(可选)打印指定类的层次结构,如果未指定,则将打印所有类层次结构(STRING,无默认值)

使用示例:

jcmd 12737 VM.class_hierarchy -i -s javax.servlet.GenericFilter

32.VM.command_line

  • 作用:打印用于启动此VM实例的命令行
  • 影响:低
  • 所需权限:java.lang.management.ManagementPermission(monitor)

33.VM.dynlibs

  • 作用:打印加载的动态库
  • 影响:低
  • 允许:java.lang.management.ManagementPermission(monitor)

34.VM.info

  • 作用:打印有关JVM环境和状态的信息
  • 影响:低
  • 允许:java.lang.management.ManagementPermission(monitor)

35.VM.log [options]

  • 作用:列出当前日志配置,启用/禁用/配置日志输出,或轮换所有日志
  • 影响:低
  • 所需权限:java.lang.management.ManagementPermission(control)
  • options:选项,必须使用key或者key=value的语法指定,可用的options如下:
    • output:(可选)要配置的输出的名称或索引。(STRING,无默认值)
    • output_options:(可选)输出的选项。(STRING,无默认值)
    • what:(可选)配置要记录的标签。(STRING,无默认值)
    • disable:(可选)关闭所有日志记录并清除日志配置。
    • list:(可选)列出当前的日志配置。(BOOLEAN,无默认值)
    • rotate:(可选)轮换所有日志。(布尔值,无默认值)

使用示例:

jcmd 12737 VM.log output what

36. VM.flags [options]

  • 作用:打印VM标志及其当前值
  • 影响:低
  • 所需权限:java.lang.management.ManagementPermission(monitor)
  • options:选项,必须使用key或者key=value的语法指定,可用的options如下:
    • -all:(可选)打印VM支持的所有标志(BOOLEAN,false)

37.VM.native_memory [options]

该功能叫做“Native Memory Tracking(NMT)”需开启如下参数,才可打开。
-XX:NativeMemoryTracking=[off | summary | detail |
打开后会带来5~10%的性能损耗。
也可用```-XX:+UnlockDiagnosticVMOptions -XX:+PrintNMTStatistics``,让JVM在退出时打印NMT报告。
参考文章:https://blog.csdn.net/varyall/article/details/86514888
————————————————

  • 作用:打印native内存使用情况。
  • 影响:中
  • 允许:java.lang.management.ManagementPermission(monitor)
  • options:选项,必须使用key或者key=value的语法指定,可用的options如下:
    • summary:(可选)请求运行时报告当前内存摘要,包括所有保留和提交的内存以及每个子系统的内存使用情况摘要(BOOLEAN,false)
    • detail:(可选)请求运行时报告每个调用站点(callsite)>= 1K的内存分配(BOOLEAN,false)
    • baseline:(可选)请求运行时以当前内存使用情况为基准,以便以后进行比较(BOOLEAN,false)
    • summary.diff:(可选)请求运行时报告与先前基准的内存摘要比较(BOOLEAN,false)
    • detail.diff:(可选)请求运行时报告与先前基准的内存详情比较,该基准显示了在不同调用站点(callsite)的内存分配活动(BOOLEAN,false)
    • shutdown:(可选)请求运行时关闭自身并释放运行时使用的内存(BOOLEAN,false)
    • statistics:(可选)打印跟踪器统计信息以进行调整(BOOLEAN,false)
    • scale:(可选)以MB,MB或者GB为单位的内存使用量(STRING,KB)

38. VM.print_touched_methods

  • 作用:打印次JVM生命周期中曾经接触过的所有方法。
  • 影响:中(取决于Java内容)

39. VM.set_flag [arguments]

  • 作用:设置VM标志
  • 影响:低
  • 所需权限:java.lang.management.ManagementPermission(control)
  • arguments:
  • 标志名称:您要设置的标志名称(STRING,无默认值)
  • 字符串值:(可选)要设置的值(STRING,无默认值)

40. VM.stringable [options]

  • 作用:转储字符串表(string table)
  • 影响:中 (取决于Java内容)
  • 所需权限:java.lang.management.ManagementPermission(monitor)
  • options:选项,必须使用key或者key=value的语法指定,可用的options如下:
    • -verbose:(可选)转储表中每个字符串的内容(BOOLEAN,false)

使用示例:

jcmd 12737 VM.stringable -verbose

41. VM.symboltable [options]

  • 作用:转储符号表
  • 影响:中(取决于Java内容)
  • 所需权限:java.lang.management.ManagementPermission(monitor)
  • options:选项,必须使用key或者key=value的语法指定,可用的options如下:
    • -verbose:(可选)转储表中每个符号的内容(BOOLEAN,false)

使用示例:

jcmd 12737 VM.symboltable -verbose

 

42 VM.systemdictionary

  • 作用:打印字典哈希表大小和存储桶长度的统计信息
  • 影响:中
  • 所需权限:java.lang.management.ManagementPermission(monitor)
  • options:选项,必须使用key或者key=value的语法指定,可用的options如下:
    • verbose:(可选)为所有class loader转储每个词典条目的内容(BOOLEAN,false)

使用示例:

jcmd 12737 VM.systemdictionary -verbose

 43.VM.system_properties

  • 作用:打印系统属性
  • 影响:低
  • 所需权限:java.util.PropertyPermission(*, read)

44.VM.uptime [options]

  • 作用:打印虚拟机的运行时间
  • 影响:低
  • options:选项,必须使用key或者key=value的语法指定,可用的options如下:
    • -date:(可选)添加带有当前日期的前缀(BOOLEAN,false)

45. VM.version

  • 作用:打印JVM版本信息
  • 影响:低
  • 所需权限:java.util.PropertyPermission(java.vm.version, read)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值