JDK自带的四大命令行工具(jstat/jstack/jmap/jhat)的使用详解

 更新时间:2026年06月05日 08:55:52   作者:码不停蹄的玄黓  
jstat、jstack、jmap、jhat这四个是 JDK 自带的线上问题排查核心工具,专门用于定位 Java 应用的性能瓶颈、内存泄漏、死锁、CPU 飙高等问题,无需额外安装,只要装了 JDK 就能用,感兴趣的小伙伴可以了解下

这四个是 JDK 自带的线上问题排查核心工具,专门用于定位 Java 应用的性能瓶颈、内存泄漏、死锁、CPU 飙高等问题,无需额外安装,只要装了 JDK 就能用。

我会用最实用、最常用的命令,直接告诉你:什么时候用、怎么用、看什么

一、先准备:获取 Java 进程 ID

所有工具第一步都需要进程 ID(PID),先执行:

jps -l

输出示例:

12345 com.example.Application
67890 sun.tools.jps.Jps

12345 就是你的 Java 应用 PID。

1. jstat:JVM 统计信息监控工具(看性能、GC)

作用:查看类加载、内存使用、GC 频率/耗时,排查 GC 频繁、内存占用高问题。

最常用命令

1)查看 GC 概况(最常用)

jstat -gc 12345 1000 10
  • 1000:每隔 1000ms(1秒)输出一次
  • 10:总共输出 10 次

关键字段

  • S0C/S1C:Survivor 区大小
  • E:Eden 区使用比例
  • O:老年代使用比例
  • YGC/YGT:Young GC 次数/耗时
  • FGC/FGT:Full GC 次数/耗时
  • GCT:GC 总耗时

排查技巧

  • FGC 快速上涨 ➜ 老年代内存泄漏
  • YGC 每秒多次 ➜ 短生命周期对象过多

2)查看堆内存使用百分比

jstat -gcutil 12345

2. jstack:堆栈跟踪工具(看线程、死锁、CPU 飙高)

作用:导出线程堆栈,排查死锁、线程阻塞、CPU 100%、程序假死

最常用命令

1)导出所有线程堆栈(保存到文件分析)

jstack 12345 > thread.log

2)直接排查死锁(自动检测)

jstack -l 12345

文件末尾会显示:Found one Java-level deadlock

排查 CPU 飙高高阶用法

找到 CPU 最高的线程 ID

top -H -p 12345

将线程 ID 转成 16 进制

printf "%x\n" 12345

在 jstack 日志中搜索该 16 进制 ID,定位耗时代码

3. jmap:内存映像工具(导出堆、看对象)

作用:导出堆内存快照(dump 文件),查看堆内对象数量、大小,定位内存泄漏。

最常用命令

1)导出堆快照(排查内存泄漏必备)

jmap -dump:format=b,file=heap.hprof 12345
  • heap.hprof:二进制堆文件,可导入工具分析
  • 注意:导出时会暂停 JVM,生产环境谨慎使用

2)查看堆中对象统计(数量+大小)

jmap -histo 12345 | head -20

输出:序号、实例数、字节数、类名

能直接看到哪个类的对象最多,快速定位泄漏点。

3)查看 JVM 堆配置

jmap -heap 12345

查看新生代、老年代大小、垃圾回收器等信息。

4. jhat:堆快照分析工具(分析 hprof 文件)

作用:解析 jmap 导出的 hprof 堆快照,提供 Web 界面查看内存对象

注意:jhat 功能简单,大型堆文件建议用 MAT(Eclipse Memory Analyzer),jhat 适合快速简单分析。

使用命令

jhat -port 9999 heap.hprof
  • 启动后访问:http://localhost:9999
  • 页面可查看:所有对象、引用关系、泄漏疑点

二、快速使用场景总结(直接背这个)

工具核心用途最常用命令
jstat看 GC、内存使用率、性能监控jstat -gc PID 1000 10
jstack看线程、死锁、CPU 飙高jstack -l PID > thread.log
jmap导出堆快照、看对象数量jmap -dump:file=heap.hprof PID
jhat分析堆快照(Web 界面)jhat -port 9999 heap.hprof

三、标准问题排查流程(实战)

  1. CPU 飙高topjstack → 定位耗时代码
  2. 内存飙升/泄漏jstat -gc 看 FGC → jmap 导出 dump → jhat/MAT 分析
  3. 程序卡死jstack 查死锁、阻塞线程
  4. GC 频繁jstat -gcutil 定位 GC 问题

总结

  1. jstat:监控 GC 和内存使用,不暂停应用
  2. jstack:抓线程堆栈,查死锁、CPU 高
  3. jmap:导出堆快照,查对象泄漏
  4. jhat:简单分析堆快照(推荐用 MAT 替代)

这四个工具是 Java 线上问题排查的基础必备技能,记住常用命令就能解决 80% 的 JVM 问题。

到此这篇关于JDK自带的四大命令行工具(jstat/jstack/jmap/jhat)的使用详解的文章就介绍到这了,更多相关JDK命令行工具使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • springboot-2.3.x最新版源码阅读环境搭建(基于gradle构建)

    springboot-2.3.x最新版源码阅读环境搭建(基于gradle构建)

    这篇文章主要介绍了springboot-2.3.x最新版源码阅读环境搭建(基于gradle构建),需要的朋友可以参考下
    2020-08-08
  • Java利用ZipOutputStream进行高效压缩的技巧详解

    Java利用ZipOutputStream进行高效压缩的技巧详解

    ZipOutputStream 是 Java 标准库中用于 创建 ZIP 文件 的核心类,位于 java.util.zip 包中,本文主要和大家介绍了Java如何使用ZipOutputStream进行高效压缩,有需要的可以了解下
    2025-07-07
  • Java面试重点中的重点之Elasticsearch核心原理

    Java面试重点中的重点之Elasticsearch核心原理

    ElasticSearch是一个基于Lucene的搜索引擎,是用Java语言开发的,能够达到实时搜索,稳定,可靠,快速,安装使用方便,作为Apache许可条款下的开放源码发布,是一种流行的企业级搜索引擎,是最受欢迎的企业搜索引擎
    2022-01-01
  • struts2.3.24+spring4.1.6+hibernate4.3.11+mysql5.5.25开发环境搭建图文教程

    struts2.3.24+spring4.1.6+hibernate4.3.11+mysql5.5.25开发环境搭建图文

    这篇文章主要介绍了struts2.3.24+spring4.1.6+hibernate4.3.11+mysql5.5.25开发环境搭建图文教程,感兴趣的小伙伴们可以参考一下
    2016-06-06
  • Java 实战项目之毕业设计管理系统的实现流程

    Java 实战项目之毕业设计管理系统的实现流程

    读万卷书不如行万里路,只学书上的理论是远远不够的,只有在实战中才能获得能力的提升,本篇文章手把手带你用java+SSM+jsp+mysql+maven实现毕业设计管理系统,大家可以在过程中查缺补漏,提升水平
    2021-11-11
  • 深入理解HashMap各个方法的源码

    深入理解HashMap各个方法的源码

    这篇文章主要介绍了深入理解HashMap各个方法的源码,HashMap初始容量不能为负数,若初始容量大于最大容量,则让它等于最大容量,负载因子必须大于0,并且传入的initialCapacity不是HashMap的容量大小,需要的朋友可以参考下
    2023-12-12
  • Java计算代码段执行时间的详细过程

    Java计算代码段执行时间的详细过程

    java里计算代码段执行时间可以有两种方法,一种是毫秒级别的计算,另一种是更精确的纳秒级别的计算,这篇文章主要介绍了java计算代码段执行时间,需要的朋友可以参考下
    2023-02-02
  • SpringBoot中到底该如何解决跨域问题

    SpringBoot中到底该如何解决跨域问题

    跨域问题更是老生常谈,随便用标题去google或百度一下,能搜出一大片解决方案,这篇文章主要给大家介绍了关于SpringBoot中到底该如何解决跨域问题的相关资料,需要的朋友可以参考下
    2022-02-02
  • Java中的流式编程问题

    Java中的流式编程问题

    这篇文章主要介绍了Java中的流式编程问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • 解决java junit单元测试@Test报错的问题

    解决java junit单元测试@Test报错的问题

    今天小编就为大家分享一篇解决java junit单元测试@Test报错的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-11-11

最新评论