JDK自带工具解析与生产问题定位指南(一)
1. 引言
Java开发工具包(JDK)内置了强大的诊断工具集,用于监控、分析和调试Java应用程序。这些工具涵盖了从进程管理、内存分析到性能监控的各个方面。本文将介绍一些最常用的Java开发工具,包括jps、jmap、jstat、jcmd、jstack、jvisualvm等,并提供它们的具体应用场景及使用方法,来帮助开发者快速定位运行时问题。
JDK诊断工具全解析与实战指南
一、核心命令行工具详解
1. 进程管理工具 jps
场景
jps是Java自带的一个命令行工具,用于显示当前系统中所有Java应用程序的简要信息。它对于快速获取运行中的Java进程ID(PID)及其主类名非常有用,尤其是在需要连接到特定进程进行进一步分析或管理时。
使用方法
- 查看所有Java进程的基本信息:只需简单地执行
jps命令。 - 获取更详细的信息:可以通过添加参数如
-l来显示完整包路径的主类名,-m来查看传递给main方法的参数,或者-v来查看传递给JVM的选项。在Linux系统中,常使用ps -ef | grep java来过滤出所有包含“java”字符串的进程的详细信息。有了jps可以精确地定位到特定的Java应用程序的进程。如果只是为了查java程序的进程号,jps -l可能会更加简洁的列出你想查找的内容。
jps -q # 仅显示进程ID(PID)
jps -l # 显示完整包路径
jps -v # 显示JVM启动参数
jps -m # 显示main方法参数
| 参数 | 功能说明 | 示例 |
|---|---|---|
| -q | 只显示 PID | jps -q → 38721 |
| -m | 显示 main 方法参数 | jps -m → 38721 MyApp arg1 |
| -l | 显示完整包名/jar路径 | jps -l → com.example.Main |
| -v | 显示 JVM 参数 | jps -v → -Xmx1024m |
| -V | 显示 JVM 参数(不包含应用参数) | jps -V → -XX:MaxPermSize=256m |
2. 内存分析工具 jmap
场景
jmap用于生成Java堆的快照(heap dump),这对于诊断内存泄漏等问题至关重要。此外,它还可以显示Java进程的内存映射或共享对象统计信息。
使用方法
- 创建堆转储文件:
jmap -dump:format=b,file=heap.bin <pid>,其中<pid>为Java进程ID。 - 查看对象分配直方图:
jmap -histo <pid>可以列出每个类实例的数量和总大小。
1. 标准参数
jmap [option] <pid>
| 参数 | 功能说明 | 注意事项 |
|---|---|---|
| -heap | 显示堆内存分布 | 可能导致服务暂停 |
| -histo[:live ] | 对象内存直方图统计 | live 参数触发 Full GC |
| -clstats | 类加载器统计(JDK8+) | 需要 attach 权限 |
| -finalizerinfo | 显示等待 finalization 的对象 | 输出信息有限 |
| -dump: | 生成堆转储文件 | 示例:format=b,file=heap.bin |
2. 堆转储选项
jmap -dump:live,format=b,file=heap.hprof 38721
| 选项 | 说明 |
|---|---|
| live | 只转储存活对象 |
| format=b | 二进制格式(必须) |
| file= | 输出文件名 |
| compression=6 | 压缩级别(0-9,JDK13+) |

3. 线程分析工具 jstack
场景
jstack用来生成Java进程的线程转储,这有助于理解程序在某一时刻的线程状态,主要用于捕获线程执行堆栈 、诊断死锁/CPU热点 。 对于排查死锁、响应慢等问题特别有效。
使用方法
- 打印线程转储:
jstack <pid>直接输出线程转储信息到标准输出。 - 将线程转储保存到文件:
jstack <pid> > thread_dump.txt
jstack -l <pid> # 显示锁附加信息
jstack -F <pid> # 强制生成线程快照(用于挂起进程)
jstack -m <pid> # 混合模式(显示Java和Native栈帧)
| 参数 | 功能说明 | 使用场景 |
|---|---|---|
| -F | 强制生成线程快照 | 进程无响应时使用 |
| -l | 显示锁信息(长格式) | 分析死锁必备 |
| -m | 混合模式(显示 native 栈) | JNI 调用问题分析 |
| -J | 传递参数到 JVM | 示例:-J-d64 使用64位模式 |
4. 统计监控工具 jstat
场景
jstat提供了对Java应用程序性能和资源使用的监控能力,特别是关于垃圾回收(GC)、编译时间等方面的统计数据。
使用方法
- 监控垃圾回收活动:
jstat -gcutil <pid> 1000每秒打印一次GC统计信息。
jstat -gcutil <pid> 1000 5 # 每1秒采样GC数据,共5次
jstat -class <pid> # 类加载统计
jstat -compiler <pid> # JIT编译统计
核心监控选项
| 参数 | 监控指标 | 关键字段说明 |
|---|---|---|
| -gc | 堆内存各区域容量 | EC/EU: Eden区容量/使用量 |
| -gccapacity | 内存池最大/最小容量 | OGCMN: 老年代最小容量 |
| -gcutil | 内存使用百分比 | O: Old区使用率,FGC: Full GC次数 |
| -gccause | GC 原因统计 | LGCC: 上次GC原因 |
| -gcnew | 新生代详细统计 | TT/MTT: 晋升阈值 |
| -gcold | 老年代元空间统计 | MU: 元空间使用量 |
| -compiler | JIT 编译统计 | Failed: 编译失败次数 |
| -class | 类加载统计 | Loaded: 已加载类数量 |
5.查看/修改 JVM 参数jinfo
场景
jinfo是一个非常实用的命令行工具,用于实时查看和修改正在运行中的Java应用程序的系统属性和JVM标志。它特别适用于需要动态调整JVM参数或检查某个Java进程是否启用了特定的JVM选项时使用。这对于调试、性能调优以及故障排查都非常有帮助。
使用方法
- 查看所有JVM标志:可以通过
jinfo -flags <pid>来查看指定Java进程的所有JVM启动参数。 - 修改JVM标志(仅限可变标志):对于支持动态修改的JVM标志,可以使用
jinfo -flag [+|-]<name>=<value> <pid>的形式进行在线调整。请注意,并非所有的JVM标志都支持这种操作方式。
jinfo [option] <pid>
| 参数 | 功能说明 | 示例 |
|---|---|---|
| -flags | 显示所有参数 | jinfo -flags 38721 |
| -sysprops | 显示系统属性 | jinfo -sysprops 38721 |
| 查看具体参数值 | jinfo MaxHeapSize 38721 | |
| -flag = | 动态修改参数 | jinfo -flag +HeapDumpOnOutOfMemoryError 38721 |
二、高级诊断工具专题
全能诊断工具 jcmd(JDK 7+)
场景
jcmd是一个多功能工具,它可以向正在运行的Java进程中发送各种诊断命令,例如触发堆转储、线程转储、GC日志记录等。
使用方法
jcmd <pid> help # 查看可用命令列表
jcmd <pid> VM.flags # 查看所有JVM参数
jcmd <pid> GC.heap_dump filename=heap.hprof # 生成堆转储
jcmd <pid> Thread.print # 生成线程快照
版本功能差异:
| 功能 | JDK 8 支持 | JDK 11+ 增强功能 |
|---|---|---|
| JFR 控制 | ❌ | ✅ 基础功能免授权 |
| Native 内存分析 | ❌ | ✅ 支持详细NMT数据 |
| 诊断命令数量 | 40+ | 60+(新增网络诊断等命令) |
1. 基础命令
jcmd <pid> help # 查看支持的命令
| 命令分类 | 示例命令 | 功能说明 |
|---|---|---|
| JVM 信息 | VM.version | 显示 JVM 版本 |
VM.command_line | 显示启动命令 | |
| 内存分析 | GC.class_histogram | 类实例统计 |
GC.heap_dump filename=heap.hprof | 生成堆转储 | |
| 线程分析 | Thread.print | 生成线程快照 |
Thread.dump_to_file -format=text filename=threads.txt | 导出线程信息 |
2. 高级诊断(JDK11+)
| 命令 | 功能说明 |
|---|---|
JVMTI.data_dump | 生成 JVMTI 数据转储 |
Compiler.codecache | 显示代码缓存使用情况 |
VM.native_memory | Native 内存分析 |
3. 飞行记录器 JFR(JDK 11+)
# 开启60秒记录(需要JDK 11+)
jcmd <pid> JFR.start name=app_profile duration=60s filename=recording.jfr# 导出记录文件
jcmd <pid> JFR.dump name=app_profile filename=recording.jfr
| 参数 | 作用说明 | 推荐配置 |
|---|---|---|
| name | 记录会话名称 | 建议使用有意义的命名 |
| duration | 记录持续时间 | 生产环境建议5-10分钟 |
| filename | 输出文件路径 | 确保磁盘空间充足 |
三、 图形化工具
| 工具 | 功能特点 |
|---|---|
| JConsole | 实时监控堆/线程/类加载/MBean |
| VisualVM | 支持堆转储分析/CPU Profiling/线程跟踪(需安装插件) |
| MAT | Eclipse Memory Analyzer(需单独下载) |
JConsole、VisualVM和MAT都是针对Java虚拟机(JVM)的性能分析和监控工具,它们在Java开发领域中发挥着重要作用。三者均提供对内存、线程和GC行为的分析能力,但在功能侧重上形成互补:JConsole作为轻量级监控工具,通过JMX协议实现实时指标可视化,适合基础性能观测;VisualVM作为集成化分析平台,兼具实时监控、CPU/内存采样分析、线程追踪等综合能力,支持插件扩展实现高级诊断;MAT则专精于堆转储文件的深度解析,通过对象支配树、内存泄漏检测等特性,为内存类问题提供根源性诊断方案。具体使用方案,将在下一篇文章详细介绍,敬请期待!
推荐学习路径
专家建议:建立诊断知识库,记录典型问题的排查路径和工具使用组合,可提升团队整体排障效率30%以上。
相关文章:
JDK自带工具解析与生产问题定位指南(一)
1. 引言 Java开发工具包(JDK)内置了强大的诊断工具集,用于监控、分析和调试Java应用程序。这些工具涵盖了从进程管理、内存分析到性能监控的各个方面。本文将介绍一些最常用的Java开发工具,包括jps、jmap、jstat、jcmd、jstack、…...
FPGA 使用 CLOCK_DEDICATED_ROUTE 约束
使用 CLOCK_DEDICATED_ROUTE 约束 CLOCK_DEDICATED_ROUTE 约束通常在从一个时钟区域中的时钟缓存驱动到另一个时钟区域中的 MMCM 或 PLL 时使 用。默认情况下, CLOCK_DEDICATED_ROUTE 约束设置为 TRUE ,并且缓存 /MMCM 或 PLL 对必须布局在相同…...
《解锁AI黑科技:数据分类聚类与可视化》
在当今数字化时代,数据如潮水般涌来,如何从海量数据中提取有价值的信息,成为了众多领域面临的关键挑战。人工智能(AI)技术的崛起,为解决这一难题提供了强大的工具。其中,能够实现数据分类与聚类…...
Java小白入门教程:Object
目录 一、定义 二、作用 三、使用场景 四、语法以及示例 1、创建Object类型的对象 2、使用 toString()方法 3、使用 equals()方法 4、使用 hashCode()方法 5、使用 getClass()方法 6、使用 clone()方法 7、使用 finalize()方法 一、定义 在Java中, object…...
记6(人工神经网络
目录 1、M-P神经元2、感知机3、Delta法则4、前馈型神经网络(Feedforward Neural Networks)5、鸢尾花数据集——单层前馈型神经网络:6、多层神经网络:增加隐含层7、实现异或运算(01、10为1,00、11为0)8、线性…...
stm32硬件实现与w25qxx通信
使用的型号为stm32f103c8t6与w25q64。 STM32CubeMX配置与引脚衔接 根据stm32f103c8t6引脚手册,采用B12-B15四个引脚与W25Q64连接,实现SPI通信。 W25Q64SCK(CLK)PB13MOSI(DI)PB15MISO(DO)PB14CS(…...
编程题-最接近的三数之和
题目: 给你一个长度为 n 的整数数组 nums 和 一个目标值 target。请你从 nums 中选出三个整数,使它们的和与 target 最接近。 返回这三个数的和。 假定每组输入只存在恰好一个解。 解法一(排序双指针): 题目要求找…...
索引的底层数据结构、B+树的结构、为什么InnoDB使用B+树而不是B树呢
索引的底层数据结构 MySQL中常用的是Hash索引和B树索引 Hash索引:基于哈希表实现的,查找速度非常快,但是由于哈希表的特性,不支持范围查找和排序,在MySQL中支持的哈希索引是自适应的,不能手动创建 B树的…...
【工欲善其事】利用 DeepSeek 实现复杂 Git 操作:从原项目剥离出子版本树并同步到新的代码库中
文章目录 利用 DeepSeek 实现复杂 Git 操作1 背景介绍2 需求描述3 思路分析4 实现过程4.1 第一次需求确认4.2 第二次需求确认4.3 第三次需求确认4.4 V3 模型:中间结果的处理4.5 方案验证,首战告捷 5 总结复盘 利用 DeepSeek 实现复杂 Git 操作 1 背景介绍…...
网络编程套接字(中)
文章目录 🍏简单的TCP网络程序服务端创建套接字服务端绑定服务端监听服务端获取连接服务端处理请求客户端创建套接字客户端连接服务器客户端发起请求服务器测试单执行流服务器的弊端 🍐多进程版的TCP网络程序捕捉SIGCHLD信号让孙子进程提供服务 …...
前端学习-事件委托(三十)
目录 前言 课前思考 for循环注册事件 语法 事件委托 1.事件委托的好处是什么? 2.事件委托是委托给了谁,父元素还是子元素 3.如何找到真正触发的元素 示例代码 总结 前言 才子佳人,自是白衣卿相 课前思考 1.如果同时给多个元素注册事件&…...
线程池以及在QT中的接口使用
文章目录 前言线程池架构组成**一、任务队列(Task Queue)****二、工作线程组(Worker Threads)****三、管理者线程(Manager Thread)** 系统协作流程图解 一、QRunnable二、QThreadPool三、线程池的应用场景W…...
c语言操作符(详细讲解)
目录 前言 一、算术操作符 一元操作符: 二元操作符: 二、赋值操作符 代码例子: 三、比较操作符 相等与不相等比较操作符: 大于和小于比较操作符: 大于等于和小于等于比较操作符: 四、逻辑操作符 逻辑与&…...
【自然语言处理(NLP)】深度学习架构:Transformer 原理及代码实现
文章目录 介绍Transformer核心组件架构图编码器(Encoder)解码器(Decoder) 优点应用代码实现导包基于位置的前馈网络残差连接后进行层规范化编码器 Block编码器解码器 Block解码器训练预测 个人主页:道友老李 欢迎加入社…...
JavaScript 入门教程
JavaScript 入门教程 JavaScript 入门教程引言学习 JavaScript 的好处常见的 JavaScript 框架和库 安装开发环境下载并安装 Node.js 和 npm安装常用开发工具(如 VS Code)配置本地开发环境 基础语法入门数据类型变量与常量运算符算术运算符比较运算符 条件…...
浅析CDN安全策略防范
CDN(内容分发网络)信息安全策略是保障内容分发网络在提供高效服务的同时,确保数据传输安全、防止恶意攻击和保护用户隐私的重要手段。以下从多个方面详细介绍CDN的信息安全策略: 1. 数据加密 数据加密是CDN信息安全策略的核心之…...
代码随想录刷题day22|(字符串篇)344.反转字符串、541.反转字符串 II
目录 一、题目思路 二、相关题目 三、总结与知识点 3.1 字符数组转换成字符串 一、题目思路 344反转字符串比较容易,双指针即可在空间复杂度为O(1)的基础上解决; 541反转字符串II :其中for循环中 i 每次的取值,不是 i&#…...
python学opencv|读取图像(五十三)原理探索:使用cv.matchTemplate()函数实现最佳图像匹配
【1】引言 前序学习进程中,已经探索了使用cv.matchTemplate()函数实现最佳图像匹配的技巧,并且成功对两个目标进行了匹配。 相关文章链接为:python学opencv|读取图像(五十二)使用cv.matchTemplate()函数实现最佳图像…...
win10部署本地deepseek-r1,chatbox,deepseek联网(谷歌网页插件Page Assist)
win10部署本地deepseek-r1,chatbox,deepseek联网(谷歌网页插件Page Assist) 前言一、本地部署DeepSeek-r1step1 安装ollamastep2 下载deepseek-r1step2.1 找到模型deepseek-r1step2.2 cmd里粘贴 后按回车,进行下载 ste…...
冯·诺依曼体系结构
目录 冯诺依曼体系结构推导 内存提高冯诺依曼体系结构效率的方法 你使用QQ和朋友聊天时,整个数据流是怎么流动的(不考虑网络情况) 与冯诺依曼体系结构相关的一些知识 冯诺依曼体系结构推导 计算机的存在就是为了解决问题,而解…...
浏览器访问 AWS ECS 上部署的 Docker 容器(监听 80 端口)
✅ 一、ECS 服务配置 Dockerfile 确保监听 80 端口 EXPOSE 80 CMD ["nginx", "-g", "daemon off;"]或 EXPOSE 80 CMD ["python3", "-m", "http.server", "80"]任务定义(Task Definition&…...
eNSP-Cloud(实现本地电脑与eNSP内设备之间通信)
说明: 想象一下,你正在用eNSP搭建一个虚拟的网络世界,里面有虚拟的路由器、交换机、电脑(PC)等等。这些设备都在你的电脑里面“运行”,它们之间可以互相通信,就像一个封闭的小王国。 但是&#…...
7.4.分块查找
一.分块查找的算法思想: 1.实例: 以上述图片的顺序表为例, 该顺序表的数据元素从整体来看是乱序的,但如果把这些数据元素分成一块一块的小区间, 第一个区间[0,1]索引上的数据元素都是小于等于10的, 第二…...
8k长序列建模,蛋白质语言模型Prot42仅利用目标蛋白序列即可生成高亲和力结合剂
蛋白质结合剂(如抗体、抑制肽)在疾病诊断、成像分析及靶向药物递送等关键场景中发挥着不可替代的作用。传统上,高特异性蛋白质结合剂的开发高度依赖噬菌体展示、定向进化等实验技术,但这类方法普遍面临资源消耗巨大、研发周期冗长…...
java 实现excel文件转pdf | 无水印 | 无限制
文章目录 目录 文章目录 前言 1.项目远程仓库配置 2.pom文件引入相关依赖 3.代码破解 二、Excel转PDF 1.代码实现 2.Aspose.License.xml 授权文件 总结 前言 java处理excel转pdf一直没找到什么好用的免费jar包工具,自己手写的难度,恐怕高级程序员花费一年的事件,也…...
Golang dig框架与GraphQL的完美结合
将 Go 的 Dig 依赖注入框架与 GraphQL 结合使用,可以显著提升应用程序的可维护性、可测试性以及灵活性。 Dig 是一个强大的依赖注入容器,能够帮助开发者更好地管理复杂的依赖关系,而 GraphQL 则是一种用于 API 的查询语言,能够提…...
Linux云原生安全:零信任架构与机密计算
Linux云原生安全:零信任架构与机密计算 构建坚不可摧的云原生防御体系 引言:云原生安全的范式革命 随着云原生技术的普及,安全边界正在从传统的网络边界向工作负载内部转移。Gartner预测,到2025年,零信任架构将成为超…...
Ascend NPU上适配Step-Audio模型
1 概述 1.1 简述 Step-Audio 是业界首个集语音理解与生成控制一体化的产品级开源实时语音对话系统,支持多语言对话(如 中文,英文,日语),语音情感(如 开心,悲伤)&#x…...
JVM暂停(Stop-The-World,STW)的原因分类及对应排查方案
JVM暂停(Stop-The-World,STW)的完整原因分类及对应排查方案,结合JVM运行机制和常见故障场景整理而成: 一、GC相关暂停 1. 安全点(Safepoint)阻塞 现象:JVM暂停但无GC日志,日志显示No GCs detected。原因:JVM等待所有线程进入安全点(如…...
优选算法第十二讲:队列 + 宽搜 优先级队列
优选算法第十二讲:队列 宽搜 && 优先级队列 1.N叉树的层序遍历2.二叉树的锯齿型层序遍历3.二叉树最大宽度4.在每个树行中找最大值5.优先级队列 -- 最后一块石头的重量6.数据流中的第K大元素7.前K个高频单词8.数据流的中位数 1.N叉树的层序遍历 2.二叉树的锯…...
