jcmd 命令_jcmd:一个可以全部统治的JDK命令行工具

jcmd 命令

我在过去的几篇文章中都引用了方便的JDK工具jcmd ,但是像我以前对jps所做的那样,只专注于它的实用性jcmd工具是随Oracle Java 7引入的,通过使用它来识别Java进程的ID (与jps相似),获取堆转储 (与jmap相似),获取线程转储 (与jstack相似),在解决 JVM应用程序 问题方面特别有用。 ),查看虚拟机特征(例如系统属性和命令行标志)(类似于jinfo ),并获取垃圾回收统计信息(类似于jstat )。 jcmd工具被称为“ 用于调查和解决JVM应用程序问题的瑞士军刀 ”和“ 隐藏的宝石”

在使用大多数JDK命令行工具(包括jcmd )时,标识要为其使用命令行工具的Java进程的进程ID(pid)通常很重要。 使用jcmd可以轻松完成此jcmd ,只需简单地运行不带任何参数的命令即可,如下面的屏幕快照所示。

201602-jcmdLists进程

在上面的示例中运行不带参数的jcmd显示了两个正在运行的Java进程( jcmd自身的pid为324,另一个Java进程的pid为7268)。 请注意,尽管在列出Java进程时jcmd工作原理与jps非常相似,但与不带参数-lm jps相比, jcmd列出的信息更多。

运行jcmd -h用于显示帮助和用法信息jcmd在下一屏幕快照证明。

201602-jcmd帮助

如刚刚所示,该帮助说明jcmd在“未给出任何选项”时“列出Java进程”。 帮助还指出,这是类似于运行行为jcmd -p ,但我认为它的意思是说运行jcmd不带选项相当于跑步jcmd -l ,这是在接下来的屏幕快照所示。

201602-jcmListsProcessesLOption

就像在不带任何选项的情况下运行jcmdjcmd -l列出了Java进程及其各自的pid。 本例中的pids不同,因为它是jcmd的不同执行, jcmd我运行的Java进程也不同。

运行jcmd -h显示相对较少的选项。 要查看jcmd支持的许多功能的帮助,需要询问jcmd特定Java进程支持哪些功能。 下一个屏幕快照对此进行了说明。 我首先运行不带选项的jcmd来发现感兴趣的Java进程的pid(在本例中为6320)。 然后,我可以运行jcmd 6320 help来查看jcmd支持哪些命令。

201602-jcmdHelpJvmProcess

上一个屏幕快照展示了jcmd支持pid标识的特定Java VM的命令。 具体来说,它指出“以下命令可用:”,然后列出它们:

  • JFR停止
  • 启动JFR
  • JFR转储
  • JFR。检查
  • VM.native_memory
  • VM.check_commercial_features
  • VM.unlock_commercial_features
  • 管理代理停止
  • ManagementAgent.start_local
  • ManagementAgent.start
  • GC.rotate_log
  • GC.class_stats
  • GC.class_histogram
  • GC.heap_dump
  • GC.run_finalization
  • GC运行
  • 线程打印
  • 虚拟机正常运行时间
  • 虚拟机标志
  • VM.system_properties
  • VM.command_line
  • 虚拟机版本
  • 救命

当针对另一个Java VM进程的pid运行jcmd <pid> help ,可能会获得不同的可用命令列表。 下一个屏幕快照说明了这一点,当针对该进程的pid为1216执行jcmd 1216 help时。

201602-jcmd-moreCmdsOnDifferentVMInstance

通过比较最后两个屏幕快照,可以清楚地看出jcmd支持针对不同Java VM实例的不同命令。 这就是为什么通过在help命令中指定pid列出特定VM支持的命令的原因。 未针对原始检查的VM列出的第二个VM可用的一些命令(在本例中为pid 1216)包括以下命令:

  • VM.log
  • 管理代理状态
  • Compiler.directives_clear
  • Compiler.directives_remove
  • Compiler.directives_add
  • Compiler.directives_print
  • VM.print_touched_methods
  • 编译器
  • 编译器代码清单
  • 编译器队列
  • VM.classloader_stats
  • JVMTI.data_dump
  • VM.stringtable
  • 虚拟机
  • VM.class_hierarchy
  • GC.finalizer_info
  • GC.heap_info
  • VM.info
  • VM.dynlibs
  • VM.set_flag

此“帮助”还建议:“有关特定命令的更多信息,请使用'help <command>'。” 下一个屏幕快照专门针对jcmdThread.print说明了如何执行此Thread.print

201602-jcmdHelpThread打印

在讨论jcmd Thread.print命令的主题时,是一个很好的时机来说明如何使用它来查看Java进程的线程堆栈。 下一个屏幕快照显示了执行jcmd <pid> Thread.print (在本例中为pid 6320的Java进程)时看到的冗长结果的开始。

201602-jcmdThreadPrint开始

jcmd支持多个VM.*命令: VM.versionVM.uptimeVM.command_lineVM.flagsVM.system_propertiesVM.native_memoryVM.classloader_stats 。 下一个屏幕快照说明了对使用pid 6320的Java进程使用jcmd <pid> VM.versionjcmd <pid> VM.uptime的情况。

201602-jcmd-vm-version-uptime

下一个屏幕快照演示了jcmd <pid> VM.command_line使用pid 6320来执行jcmd <pid> VM.command_line

201602-jcmd-vm-命令行

从该屏幕快照(其中显示了运行jcmd 6320 VM.command_line的输出的顶部)中,我们可以从为此过程提供的JVM命令行参数中看到它是与NetBeans相关的过程。 使用pid 6320对Java进程运行命令jcmd <pid> VM.flags显示传递给该进程的HotSpot选项。

201602-jcmd-vm-flags

可以使用jcmd <pid> VM.system_properties列出Java进程使用的系统属性,这将在下一个屏幕快照中进行说明。

201602-jcmd-vm-system-properties

当尝试对尚未启用本机内存跟踪 (NMT)的Java进程运行jcmd <pid> VM.native_memory ,将显示错误消息“未启用本机内存跟踪”,如下一个屏幕快照所示。

201602-jcmd-native-memory-未启用

要使用命令jcmd <pid> VM.native_memory ,应使用-XX:NativeMemoryTracking=summary-XX:NativeMemoryTracking=detail选项启动要测量的JVM(Java进程)。 使用这些选项之一启动VM后,可以针对该JVM进程执行命令jcmd <pid> VM.native_memory baseline ,然后执行jcmd <pid> VM.native_memory detail.diff

jcmd <pid> VM.classloader_stats命令可提供对类加载器的了解。 下一个针对pid为1216的Java进程的屏幕快照中显示了该快照:

201602-jcmd-classloader-stats

jcmd <pid> VM.class_hierarchy是一个有趣的命令,可显示在目标Java VM进程中加载​​的类的层次结构。

201602-jcmd-vm-class-hierarchy

jcmd <pid> VM.dynlibs可用于查看动态库信息。 在下一个屏幕快照中对此进行了演示,该快照是使用pid 1216针对Java进程执行的。

201602-jcmd-vm-dynlibs

jcmd <pid> VM.info列出了许多有关目标Java VM进程的信息,包括VM摘要以及有关该进程,垃圾回收事件,动态库,提供给VM的参数以及主机某些特征的信息。机。 在jcmd 1216 VM.info的下一个屏幕快照中演示了此输出开始的一小部分:

201602-jcmd-vm-info

下一个屏幕快照展示了jcmd <pid> VM.stringtablejcmd <pid> VM.symboltable

201602-jcmd-vm-stringtable-symboltable

下一个屏幕快照中演示了jcmd <pid> Compiler.directives_print使用。

201602-jcmd-compiler-directives-print

jcmd支持的几个命令支持管理和监视垃圾收集。 其中两个是jcmd <pid> GC.run [类似于System.gc() ]和jcmd <pid> GC.run_finalization [类似于System.runFinalization() ]。 在下一个屏幕快照中将演示其中两个。

201602-jcmd-gc-run

命令jcmd <pid> GC.class_histogram提供了一种方便的方法来查看对象直方图 ,如下一个屏幕快照所示。

201602-jcmd-gc-class直方图

jcmd可用于使用jcmd <pid> GC.heap_dump <filename>针对正在运行的Java VM生jcmd <pid> GC.heap_dump <filename>转储,这将在下一个屏幕快照中进行演示。

201602-jcmd-heapDump

现在,可以使用jhat命令来处理jcmd生成的堆转储,如以下两个屏幕快照所示。

201602-jcmd-jat

201602-jcmd-heapdump-web

有些jcmd命令仅适用于使用-XX:+UnlockDiagnosticVMOptions JVM标志启动的Java VM。 下一个屏幕快照演示了当我尝试对未以标志-XX:+UnlockDiagnosticVMOptions jcmd <pid> GC.class_stats的Java VM运行jcmd <pid> GC.class_stats时发生的情况。

201602-jcmdClassStatsNA

使用-XX:+UnlockDiagnosticVMOptions启动目标VM时, jcmd <pid> GC.class_stats显示“ 有关Java类元数据的统计信息 ”。

201602-jcmd-class-stats-displayed

这篇文章介绍了jcmd提供的一些命令,但没有涉及与Java Flight Recorder [ JFR ](名称以JFR.*开头的命令)相关的功能,以检查和启用商业功能( jcmd <pid> VM.check_commercial_featuresjcmd <pid> VM.unlock_commercial_features )。

在一个命令行工具中, jcmd汇集了几个命令行JDK工具的功能。 这篇文章演示了jcmd提供的一些功能。

翻译自: https://www.javacodegeeks.com/2016/03/jcmd-one-jdk-command-line-tool-rule.html

jcmd 命令

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值