您当前的位置:首页 > 电脑百科 > 程序开发 > 语言 > JAVA

JDK命令行工具详解,这四个工具你都会用吗?

时间:2023-10-09 12:26:13  来源:  作者:Spring全家桶实战案例源码

环境:JDK1.8.0_92

JDK(JAVA Development Kit)提供了一系列的命令行工具,用于帮助开发人员进行问题排查。以下是关于JDK命令行工具问题排查的一些常见操作:

  1. 使用jps查看虚拟机进程:jps是一个用于显示Java虚拟机(JVM)进程信息的工具。通过jps指令可以获取到正在运行的JVM进程的ID(PID),这对于后续的问题排查非常有用。
  2. 使用jstat监视虚拟机运行时信息:jstat是一个用于监视虚拟机运行时各种信息的工具。它可以监控类加载数量、内存使用情况、垃圾回收情况等信息,对于排查内存泄漏、GC问题等非常有用。
  3. 使用jstack获取线程堆栈信息:jstack是一个用于获取Java线程堆栈信息的工具。当JVM进程出现异常或卡顿时,可以使用jstack指令获取线程堆栈信息,以帮助开发人员找到问题所在。
  4. 使用jmap生成堆转储文件:jmap是一个用于生成Java堆转储文件的工具。当JVM内存溢出或需要排查内存问题时,可以使用jmap指令生成堆转储文件,以帮助开发人员找到内存泄漏或垃圾回收等问题。

以上是JDK命令行工具问题排查中常用的几个操作,它们可以帮助开发人员快速定位和解决问题。当然,还有其他JDK提供的工具也可以用于问题排查,例如jconsole、jvisualvm等。

JDK命令行工具所在目录%JAVA_HOME%bin 目录下:

JDK命令行工具详解,这四个工具你都会用吗?图片

这里你会发现这些工具的大小基本上都是17kb左右。为何?因为这些工具大部分都是

%JAVA_HOME%bintools.jar这个jar中的类实现的,而这里的可执行exe文件只是对这写功能做了简单的一个封装而已。

对应到tools.jar中

JDK命令行工具详解,这四个工具你都会用吗?图片

接下来对常用的工具做介绍:

1.jps

显示所有当前正在运行的HosSpot虚拟机进程。

JDK命令行工具详解,这四个工具你都会用吗?图片

参数:

-l :输出完整的包名+类名,如果执行的是jar包,输出jar包的路径。

JDK命令行工具详解,这四个工具你都会用吗?图片

-m:输出启动程序时,传的参数信息。

测试程序:

public class JpsMAIn {


  public static void main(String[] args) throws Exception {
    System.out.println(Arrays.toString(args)) ;
    System.in.read() ;
  }


}

启动参数设置:

JDK命令行工具详解,这四个工具你都会用吗?图片

启动时设置了3个参数分别是:a , b , c

查看:

JDK命令行工具详解,这四个工具你都会用吗?图片

-v:输出进程启动时的jvm参数。

还是以上面的测试程序为例:

启动jvm参数设置:

JDK命令行工具详解,这四个工具你都会用吗?图片

查看:

JDK命令行工具详解,这四个工具你都会用吗?图片

-q:只输出进程号。

JDK命令行工具详解,这四个工具你都会用吗?图片

到此jps工具介绍完毕。

2.jstat

用于监视虚拟机运行时的各种信息。如:类加载,内存,垃圾回收等信息。

使用格式:

jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]]

vmid:表示jvm进程号。

interval:表示查询间隔(单位秒 s,毫秒 ms)。

count:表示查询次数

查看option有哪些选项信息(也就是可以监控哪些信息)

命令:

jstat -options

JDK命令行工具详解,这四个工具你都会用吗?图片

-class: 显示类加载,卸载的数量,总空间及加载所耗时。

JDK命令行工具详解,这四个工具你都会用吗?图片

-compiler:显示JIT编译器编译过的方法,耗时等信息。

JDK命令行工具详解,这四个工具你都会用吗?图片

-gc:监视Java堆的使用情况,GC时间等信息。

JDK命令行工具详解,这四个工具你都会用吗?图片

S0C:第一个幸存区的大小

S1C:第二个幸存区的大小

S0U:第一个幸存区的使用大小

S1U:第二个幸存区的使用大小

EC:伊甸园区的大小

EU:伊甸园区的使用大小

OC:老年代大小

OU:老年代使用大小

MC:方法区大小

MU:方法区使用大小

CCSC:压缩类空间大小

CCSU:压缩类空间使用大小

YGC:年轻代垃圾回收次数

YGCT:年轻代垃圾回收消耗时间

FGC:老年代垃圾回收次数

FGCT:老年代垃圾回收消耗时间

GCT:垃圾回收消耗总时间

-gcutil:该选项与-gc基本相同,但他主要关注的是已使用空间占总空间的百分比。

S0:幸存1区当前使用比例
S1:幸存2区当前使用比例
E:伊甸园区使用比例
O:老年代使用比例
M:元数据区使用比例
CCS:压缩使用比例
YGC:年轻代垃圾回收次数
FGC:老年代垃圾回收次数
FGCT:老年代垃圾回收消耗时间
GCT:垃圾回收消耗总时间

-gcnew:监视年轻代GC情况。

 

JDK命令行工具详解,这四个工具你都会用吗?图片

图片

-gcold:监视老轻代GC情况。

JDK命令行工具详解,这四个工具你都会用吗?图片

示例:

jstat -gc 16480 3s

每3秒统计一次gc信息。

JDK命令行工具详解,这四个工具你都会用吗?图片

3. jinfo

实时查看和调整虚拟机各项参数。

使用:

jinfo option pid

示例:
输出当前jvm进程的完整信息

JDK命令行工具详解,这四个工具你都会用吗?图片

查询具体jvm参数值信息:

jinfo -flag CICompilerCount 16480

4. jmap

用于生成堆转储快照信息。

使用格式:

jmap [option] pid

option参数说明:

-dump:生成Java堆转储快照

jmap -dump:live,format=b,file=heap.bin <pid>

示例:

JDK命令行工具详解,这四个工具你都会用吗?图片

JDK命令行工具详解,这四个工具你都会用吗?图片

-heap:显示Java堆详细信息。如:使用的垃圾回收期,参数配置,分代信息等。

jmap -heap <pid>

示例:

JDK命令行工具详解,这四个工具你都会用吗?图片

-histo:显示堆中对象的统计信息,包括类,实例数,合计容量等。

jmap -histo <pid>

示例:

JDK命令行工具详解,这四个工具你都会用吗?图片

5. jhat

堆转储文件分析工具。

使用格式:

jhat <file>

分析上面生成的文件

示例:

JDK命令行工具详解,这四个工具你都会用吗?图片

这里生成了一个端口为7000的服务,直接访问

JDK命令行工具详解,这四个工具你都会用吗?图片

6. jstack

用于生成当前进程中当前时刻线程的快照。

使用格式:

jstack [option] <pid>

参数:

-F:当正常输出的请求不被响应时,强制输出线程堆栈。

-l:除了显示堆栈信息,还显示关于锁的相关信息。

-m:如果调用的是本地方法,可以显示C/C++的堆栈。

示例:

JDK命令行工具详解,这四个工具你都会用吗?图片

JDK命令行工具详解,这四个工具你都会用吗?图片

完毕!!!



Tags:JDK   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
JDK17 与 JDK11 特性差异浅谈
从 JDK11 到 JDK17 ,Java 的发展经历了一系列重要的里程碑。其中最重要的是 JDK17 的发布,这是一个长期支持(LTS)版本,它将获得长期的更新和支持,有助于保持程序的稳定性和可靠性...【详细内容】
2024-01-26  Search: JDK  点击:(88)  评论:(0)  加入收藏
响应式编程又变天了?看JDK21虚拟线程如何颠覆!
命令式风格编程一直深受开发者喜爱,如 if-then-else、while 循环、函数和代码块等结构使代码易理解、调试,异常易追踪。然而,像所有好的东西一样,通常也有问题。这种编程风格导...【详细内容】
2023-12-28  Search: JDK  点击:(100)  评论:(0)  加入收藏
JDK11 升级 JDK17 最全实践干货来了
1、前言 上篇文章给大家带来了 JDK8 升级 JDK11 的最全实践,相信大家阅读后已经对 JDK11 有了比较深入的了解。2021 年 9 月 14 日,Oracle 发布了可以长期支持的 JDK17 版本,那...【详细内容】
2023-11-15  Search: JDK  点击:(329)  评论:(0)  加入收藏
一起来了解JDK1.8中的CAS与synchronized机制
在JDK1.8 中,ConcurrentHashMap是一个非常重要的线程安全的Map 类型。它采用了CAS 和synchronized 两种机制来实现线程安全,以保证在多线程环境下数据的一致性和正确性。首先,...【详细内容】
2023-11-01  Search: JDK  点击:(304)  评论:(0)  加入收藏
JDK21 性能提升 20 倍
JDK21 发布已经过去1个月时间了,除了每次发版必然更新的GC机制,和一些增强功能外,还引入了一个全新的概念&mdash;&mdash;虚拟线程。什么是虚拟线程先来看一下官方对虚拟线程(Vis...【详细内容】
2023-10-20  Search: JDK  点击:(242)  评论:(0)  加入收藏
一文详解 JDK1.8 的 Lambda、Stream、LocalDateTime
今天跟小伙伴们聊聊 Java中JDK1.8的一些新语法特性使用,主要是Lambda、Stream和LocalDate日期的一些使用讲解。LambdaLambda介绍Lambda 表达式(lambda expression)是一个匿名...【详细内容】
2023-10-10  Search: JDK  点击:(331)  评论:(0)  加入收藏
JDK命令行工具详解,这四个工具你都会用吗?
环境:JDK1.8.0_92JDK(Java Development Kit)提供了一系列的命令行工具,用于帮助开发人员进行问题排查。以下是关于JDK命令行工具问题排查的一些常见操作: 使用jps查看虚拟机进程:j...【详细内容】
2023-10-09  Search: JDK  点击:(298)  评论:(0)  加入收藏
JDK为什么废弃永久代,而引入元空间
今天我们来说说这个 JVM 的相关知识,因为面试简直是问到麻木的问题,那就是关于 JVM 的相关知识,今天了不起再次来和大家聊一下这个知识,我们从一些比较奇怪的问题说起,也不说那些...【详细内容】
2023-09-28  Search: JDK  点击:(258)  评论:(0)  加入收藏
图文并茂解释 Java JVM、JRE 和 JDK
在本章中,我们将讨论 Java 编程语言中 JVM、JRE 和 JDK 的一个重要定义。我们还讨论了 JVM、JRE 和 JDK 之间的区别。Java 技术既是一种编程语言又是一个平台。Java 编程语言...【详细内容】
2023-09-27  Search: JDK  点击:(297)  评论:(0)  加入收藏
如何给Alpine Linux安装Oracle JDK
Alpine使用的不是正统的glibc,对于一些强依赖glibc的系统建议不要使用Alpine,比如使用了Oracle JDK的系统,建议在Alpine换成OpenJDK。Alpine官方给出了Alpine的三大特征 Small...【详细内容】
2023-09-16  Search: JDK  点击:(252)  评论:(0)  加入收藏
▌简易百科推荐
Java 8 内存管理原理解析及内存故障排查实践
本文介绍Java8虚拟机的内存区域划分、内存垃圾回收工作原理解析、虚拟机内存分配配置,以及各垃圾收集器优缺点及场景应用、实践内存故障场景排查诊断,方便读者面临内存故障时...【详细内容】
2024-03-20  vivo互联网技术    Tags:Java 8   点击:(14)  评论:(0)  加入收藏
如何编写高性能的Java代码
作者 | 波哥审校 | 重楼在当今软件开发领域,编写高性能的Java代码是至关重要的。Java作为一种流行的编程语言,拥有强大的生态系统和丰富的工具链,但是要写出性能优异的Java代码...【详细内容】
2024-03-20    51CTO  Tags:Java代码   点击:(21)  评论:(0)  加入收藏
在Java应用程序中释放峰值性能:配置文件引导优化(PGO)概述
译者 | 李睿审校 | 重楼在Java开发领域,优化应用程序的性能是开发人员的持续追求。配置文件引导优化(Profile-Guided Optimization,PGO)是一种功能强大的技术,能够显著地提高Ja...【详细内容】
2024-03-18    51CTO  Tags:Java   点击:(24)  评论:(0)  加入收藏
Java生产环境下性能监控与调优详解
堆是 JVM 内存中最大的一块内存空间,该内存被所有线程共享,几乎所有对象和数组都被分配到了堆内存中。堆被划分为新生代和老年代,新生代又被进一步划分为 Eden 和 Survivor 区,...【详细内容】
2024-02-04  大雷家吃饭    Tags:Java   点击:(56)  评论:(0)  加入收藏
在项目中如何避免和解决Java内存泄漏问题
在Java中,内存泄漏通常指的是程序中存在一些不再使用的对象或数据结构仍然保持对内存的引用,从而导致这些对象无法被垃圾回收器回收,最终导致内存占用不断增加,进而影响程序的性...【详细内容】
2024-02-01  编程技术汇  今日头条  Tags:Java   点击:(68)  评论:(0)  加入收藏
Java中的缓存技术及其使用场景
Java中的缓存技术是一种优化手段,用于提高应用程序的性能和响应速度。缓存技术通过将计算结果或者经常访问的数据存储在快速访问的存储介质中,以便下次需要时可以更快地获取。...【详细内容】
2024-01-30  编程技术汇    Tags:Java   点击:(72)  评论:(0)  加入收藏
JDK17 与 JDK11 特性差异浅谈
从 JDK11 到 JDK17 ,Java 的发展经历了一系列重要的里程碑。其中最重要的是 JDK17 的发布,这是一个长期支持(LTS)版本,它将获得长期的更新和支持,有助于保持程序的稳定性和可靠性...【详细内容】
2024-01-26  政采云技术  51CTO  Tags:JDK17   点击:(88)  评论:(0)  加入收藏
Java并发编程高阶技术
随着计算机硬件的发展,多核处理器的普及和内存容量的增加,利用多线程实现异步并发成为提升程序性能的重要途径。在Java中,多线程的使用能够更好地发挥硬件资源,提高程序的响应...【详细内容】
2024-01-19  大雷家吃饭    Tags:Java   点击:(105)  评论:(0)  加入收藏
这篇文章彻底让你了解Java与RPA
前段时间更新系统的时候,发现多了一个名为Power Automate的应用,打开了解后发现是一个自动化应用,根据其描述,可以自动执行所有日常任务,说的还是比较夸张,简单用了下,对于office、...【详细内容】
2024-01-17  Java技术指北  微信公众号  Tags:Java   点击:(95)  评论:(0)  加入收藏
Java 在 2023 年仍然流行的 25 个原因
译者 | 刘汪洋审校 | 重楼学习 Java 的过程中,我意识到在 90 年代末 OOP 正值鼎盛时期,Java 作为能够真正实现这些概念的语言显得尤为突出(尽管我此前学过 C++,但相比 Java 影响...【详细内容】
2024-01-10  刘汪洋  51CTO  Tags:Java   点击:(74)  评论:(0)  加入收藏
站内最新
站内热门
站内头条