JVM之jcmd命令详解

news2025/5/14 0:14:45

jcmd 是 Oracle JDK(Java Development Kit)自 JDK 7 起引入的一个强大的诊断工具,用于与正在运行的 JVM(Java Virtual Machine)实例进行交互。它允许用户执行各种诊断命令,比如线程堆栈分析、堆转储、GC 信息、类加载器统计等,非常适合在生产环境中对 Java 应用程序进行调试和监控。

一、jcmd 命令基本语法

jcmd <pid | main-class> <command> [options]
  • <pid>:目标 Java 进程的进程 ID。
  • <main-class>:目标 Java 应用的主类名(可以省略 jar 路径)。
  • <command>:具体的诊断命令,比如 VM.flags
  • [options]:命令附带的参数(具体取决于命令)。

二、查看可用的 Java 进程

jcmd
输出
970 com.dzy.Main
67890 org.apache.catalina.startup.Bootstrap

表示当前有两个 Java 进程在运行,它们的进程 ID 分别是 970 和 67890。


三、常用命令详解与使用示例

1. 查看所有支持的命令

jcmd <pid> help
用法
jcmd 970 help
输出

列出该 JVM 实例支持的所有命令:

970:
VM.version
VM.command_line
VM.flags
Thread.print
GC.heap_info
GC.run
GC.class_histogram
...

2. 查看 JVM 版本信息

jcmd <pid> VM.version
用法
jcmd 970 VM.version
输出
970:
Java HotSpot(TM) 64-Bit Server VM version 17.0.9+11-LTS-201
JDK 17.0.9

3. 查看启动参数

jcmd <pid> VM.command_line
用法
jcmd 970 VM.command_line
输出
Command line:  -Xmx2G -Xms1G -Dspring.profiles.active=prod -jar app.jar

4. 查看 JVM 参数(flags)

jcmd <pid> VM.flags
用法
jcmd 970 VM.flags
输出
-XX:InitialHeapSize=1073741824 -XX:MaxHeapSize=2147483648 -XX:+UseG1GC

5. 打印线程堆栈(类似 jstack

jcmd <pid> Thread.print
用法
jcmd 970 Thread.print
输出

列出所有线程的栈信息,包括锁等待、阻塞等,非常适合死锁分析。

6. 强制触发 GC

jcmd <pid> GC.run
用法
jcmd 970 GC.run

此命令不会显示太多输出,但会触发一次完全 GC。

7. 获取堆信息(heap 使用情况)

jcmd <pid> GC.heap_info
用法
jcmd 970 GC.heap_info
输出
Heap Configuration:
   MinHeapFreeRatio         = 40
   MaxHeapFreeRatio         = 70
   ...
Heap Usage:
   G1 Heap:
      regions  = 2048
      capacity = 2048M
      used     = 1024M
      free     = 1024M

8. 导出 heap dump(堆快照)

jcmd <pid> GC.heap_dump /path/to/heapdump.hprof
用法
jcmd 970 GC.heap_dump /tmp/app-heap.hprof

文件可以用 MAT 或 VisualVM 分析。

9. 类直方图(类实例计数)

jcmd <pid> GC.class_histogram
用法
jcmd 970 GC.class_histogram
或者输出到文件
jcmd 970 GC.class_histogram > histogram.txt
输出
 num     #instances         #bytes  class name
----------------------------------------------
   1:        10000        1600000  [C
   2:         5000         800000  java.lang.String
   3:         3000         720000  java.util.HashMap

10. 导出类加载器信息

jcmd <pid> VM.class_loader_stats
用法
jcmd 970 VM.class_loader_stats
输出

统计各类加载器加载的类数量、占用内存等信息。

11. 检查是否发生了死锁

jcmd <pid> Thread.print
用法
jcmd 970 Thread.print

系统会显示哪些线程在等待锁、拥有锁,如果存在死锁,会提示 Found one Java-level deadlock.

12. 查看 Metaspace 使用情况

jcmd <pid> VM.native_memory summary
用法
jcmd 970 VM.native_memory summary

需要启动 JVM 时开启:

-XX:NativeMemoryTracking=summary

13. 查看系统属性(类似 System.getProperties)

jcmd <pid> VM.system_properties
用法
jcmd 970 VM.system_properties

14. 使用 Java Flight Recorder(JDK 11+)

JFR.start, JFR.dump, JFR.stop

# 启动 JFR
jcmd 970 JFR.start name=profile settings=profile duration=60s filename=/tmp/recording.jfr

# 手动 dump
jcmd 970 JFR.dump name=profile filename=/tmp/manual.jfr

# 停止 JFR
jcmd 970 JFR.stop name=profile

15. 查看 JIT 编译缓存区状态

jcmd <pid> Compiler.codecache
用法
jcmd 970 Compiler.codecache

四、常见场景使用

性能监控中查看当前内存使用情况

jcmd $(pidof java) GC.heap_info

导出内存快照进行 OOM 分析

jcmd $(pidof java) GC.heap_dump /tmp/dump-$(date +%s).hprof

分析线程死锁或阻塞线程

jcmd $(pidof java) Thread.print > /tmp/thread-dump.log

定时触发 GC 以排查内存回收异常

watch -n 60 "jcmd $(pidof java) GC.run"

Java 服务卡顿,想排查是否 GC 频繁

jcmd <pid> GC.heap_info
jcmd <pid> GC.class_histogram
jcmd <pid> GC.run
jcmd <pid> GC.class_histogram

比较前后对象数量是否减少,分析垃圾回收效率。

服务 CPU 飙高,定位是哪条线程

  1. 查看线程信息(找到耗 CPU 的线程)
top -Hp <pid>
  1. 将该线程 TID 转为十六进制(假设是 970 → 0x3039)
print "%x/n" <pid>
  1. jcmd 输出中查找栈
jcmd <pid> Thread.print | grep -A 20 0x3039

导出类实例占用查看内存增长

jcmd <pid> GC.class_histogram > before.txt
# 10分钟后
jcmd <pid> GC.class_histogram > after.txt
diff before.txt after.txt

分析 JVM 启动参数差异

jcmd <pid> VM.flags
jcmd <pid> VM.command_line

五、注意

  • jcmd 只能对当前用户启动的 Java 进程使用,或者以 root 权限运行。
  • 输出信息比较多,建议重定向到文件进行分析。
  • jstackjmap 等相比,jcmd 更统一、更高效。
功能命令
查看进程列表jcmd
查看支持命令jcmd <pid> help
JVM 版本jcmd <pid> VM.version
JVM 启动参数jcmd <pid> VM.command_line / VM.flags
手动 GCjcmd <pid> GC.run
打印线程堆栈jcmd <pid> Thread.print
类占用分析jcmd <pid> GC.class_histogram
原生内存jcmd <pid> VM.native_memory summary
启动/导出 JFRjcmd <pid> JFR.*

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2375006.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Qt】Qt 构建系统详解:qmake 入门到项目实战

Qt 构建系统详解&#xff1a;qmake 入门到项目实战 本文将系统介绍 Qt 构建工具 qmake 的用法&#xff0c;并通过一个完整的项目结构示例&#xff0c;帮助你掌握 .pro 文件编写、子项目管理、模块依赖等核心技能。 &#x1f9ed; 一、什么是 qmake&#xff1f; qmake 是 Qt 提…

《Zabbix Proxy分布式监控实战:从安装到配置全解析》

注意&#xff1a;实验所需的zabbix服务器的搭建可参考博客 zabbix 的docker安装_docker安装zabbix-CSDN博客 1.1 实验介绍 1.1.1 实验目的 本实验旨在搭建一个基于Zabbix的监控系统&#xff0c;通过安装和配置Zabbix Proxy、MySQL数据库以及Zabbix Agent&#xff0c;实现分…

华为配置篇-RSTP/MSTP实验

MSTP 一、简介二、常用命令总结三、实验 一、简介 RSTP&#xff08;快速生成树协议&#xff09;​ RSTP&#xff08;Rapid Spanning Tree Protocol&#xff09;是 STP 的改进版本&#xff0c;基于 ​​IEEE 802.1w 标准​​&#xff0c;核心目标是解决传统 STP 收敛速度慢的问…

git如何将本地 dev 分支与远程 dev 分支同步

要让本地 dev 分支与远程 dev 分支完全同步&#xff08;丢弃本地多余的提交记录&#xff09;&#xff0c;可以按照以下步骤操作&#xff1a; 1. ​​获取远程最新状态​ git fetch origin dev # 拉取远程 dev 分支的最新提交&#xff0c;但不会修改本地代码 IDEA中点击fetc…

Unity基础学习(九)输入系统全解析:鼠标、键盘与轴控制

目录 一、Input类 1. 鼠标输入 2. 键盘输入 3. 默认轴输入 &#xff08;1&#xff09; 基础参数 &#xff08;2&#xff09;按键绑定参数 &#xff08;3&#xff09;输入响应参数 &#xff08;4&#xff09;输入类型与设备参数 &#xff08;5&#xff09;不同类型轴的参…

QT:获取软件界面窗口的尺寸大小2025.5.8

在Windows系统中&#xff0c;获取软件界面窗口的尺寸大小可以通过多种方法实现&#xff0c;以下是基于不同场景的详细解决方案&#xff1a; 方法1&#xff1a;使用Windows API获取窗口尺寸 适用于获取外部应用程序窗口的尺寸&#xff08;如记事本、计算器等&#xff09;。 步…

【ML-Agents】ML-Agents示例项目导入unity报错解决

最近在跑ML-Agents的示例代码&#xff0c;无奈往unity中导入项目后&#xff0c;就出现报错。本文简要描述了各个报错的解决方法。 文章目录 一、error CS0234: The type or namespace name InputSystem does not exist in the namespace UnityEngine (are you missing an assem…

Transformer Decoder-Only 参数量计算

Transformer 的 Decoder-Only 架构&#xff08;如 GPT 系列模型&#xff09;是当前大语言模型的主流架构&#xff0c;其参数量主要由以下几个部分组成&#xff1a; 嵌入层&#xff08;Embedding Layer&#xff09;自注意力层&#xff08;Self-Attention Layers&#xff09;前馈…

uni-app 中的条件编译与跨端兼容

uni-app 为了实现一套代码编译到多个平台&#xff08;包括小程序&#xff0c;App&#xff0c;H5 等&#xff09;&#xff0c;引入了条件编译机制。 通过条件编译&#xff0c;我们可以针对不同的平台编写特定的代码&#xff0c;从而实现跨端兼容。 一、条件编译的作用 平台差异…

Unity接入SDK之修改Unity启动页面

原理就是在Android Studio新建Activity继承UnityPlayerActivity&#xff0c;然后再Unity中修改启动页面。 一&#xff0c;Android Studio篇 首先新建一个项目&#xff0c; 新建完成之后基于新建的项目新建一个module&#xff0c;选择为Android Library类型 新建的Library再目…

yarn workspace使用指南

作用 Yarn workspace 是 Yarn 包管理工具中的一个功能&#xff0c;主要用于管理多包项目&#xff08;monorepo&#xff09;。它的主要作用如下&#xff1a; 支持多包结构&#xff1a;允许在一个仓库中管理多个独立的包或项目。项目间依赖管理&#xff1a;方便地在不同包之间添…

VUE el-select下拉框动态设置禁用,删除后恢复可选择

场景&#xff1a;点击新增添加按钮&#xff0c;列表table会新增一条包含下拉菜单的数据&#xff0c;如果其中任何一个下拉框选择了某个值&#xff0c;那么新增的下拉菜单的选项中该值是禁用状态&#xff0c;只能选择其他未被选中过的值。点击删除按钮后&#xff0c;已禁用的选项…

FPGA----基于ALINX提供的debian实现TCF

引言:接上问,我们使用自制的image.ub和boot.bin以及ALINX提供的debian8根文件系统,构建了petalinux,但是经测试,该文件系统无法启用TCF服务,即无法与Xilinx SDK建立连接,那么我们应该如何解决? FPGA----基于ZYNQ 7020实现定制化的EPICS通信系统-CSDN博客文章浏览阅读4…

木马查杀篇—Opcode提取

【前言】 介绍Opcode的提取方法&#xff0c;并探讨多种机器学习算法在Webshell检测中的应用&#xff0c;理解如何在实际项目中应用Opcode进行高效的Webshell检测。 Ⅰ 基本概念 Opcode&#xff1a;计算机指令的一部分&#xff0c;也叫字节码&#xff0c;一个php文件可以抽取出…

国产化Excel处理控件Spire.XLS系列教程:如何通过 C# 删除 Excel 工作表中的筛选器

在 Excel 文件中&#xff0c;筛选器&#xff08;Filter&#xff09;是一个常用的数据处理工具&#xff0c;可以帮助用户快速按条件筛选数据行。但在数据整理完成、导出、共享或打印之前&#xff0c;往往需要 删除 Excel 工作表中的筛选器&#xff0c;移除列标题中的下拉筛选按钮…

[sklearn] 特征工程

一.字典数据抽取 def dictvec():"""字典数据抽取:return: None"""# 实例化# sparse改为True,输出的是每个不为零位置的坐标&#xff0c;稀疏矩阵可以节省存储空间dict DictVectorizer(sparseFalse) #矩阵中存在大量的0&#xff0c;sparse存储只…

CI/CD与DevOps流程流程简述(提供思路)

一 CI/CD流程详解&#xff1a;代码集成、测试与发布部署 引言 在软件开发的世界里&#xff0c;CI/CD&#xff08;持续集成/持续交付&#xff09;就像是一套精密的流水线&#xff0c;确保代码从开发到上线的整个过程高效、稳定。我作为一名资深的软件工程师&#xff0c;接下来…

S7-1500——零基础入门1、工业编程基本概念

工业编程基本概念 一,数制与基本数据类型二,数字量信号三,模拟量信号一,数制与基本数据类型 本节主要内容 类别内容主题数制与基本数据类型数制讲解十进制、十六进制、二进制及其进位规则;基数、位权概念数据类型介绍PLC 使用的数据类型:未序列数据类型(bit、byte、wor…

六、快速启动框架:SpringBoot3实战

六、快速启动框架&#xff1a;SpringBoot3实战 目录 一、SpringBoot3介绍 1.1 SpringBoot3简介1.2 系统要求1.3 快速入门1.4 入门总结 二、SpringBoot3配置文件 2.1 统一配置管理概述2.2 属性配置文件使用2.3 YAML配置文件使用2.4 批量配置文件注入2.5 多环境配置和使用 三、…

万兴PDF-PDFelement v11.4.13.3417

万兴PDF专家(Wondershare PDFelement)是一款国产PDF文档全方位解决方案.万兴PDF编辑器软件万兴PDF中文版,专注于PDF的创建,编辑,转换,签名,压缩,合并,比较等功能.万兴PDF专业版PDF编辑软件,以简约风格及强大的功能在国外名声大噪,除了传统功能外,还提供OCR扫描,表格识别,创建笔…