当前位置:首页 > 科技  > 软件

【JVM问题排查】JDK命令行工具详解,这四个工具你都会用吗?

来源: 责编: 时间:2023-10-10 18:31:54 400观看
导读环境:JDK1.8.0_92JDK(Java Development Kit)提供了一系列的命令行工具,用于帮助开发人员进行问题排查。以下是关于JDK命令行工具问题排查的一些常见操作:使用jps查看虚拟机进程:jps是一个用于显示Java虚拟机(JVM)进程信息的工

环境:JDK1.8.0_92VoI28资讯网——每日最新资讯28at.com

JDK(Java Development Kit)提供了一系列的命令行工具,用于帮助开发人员进行问题排查。以下是关于JDK命令行工具问题排查的一些常见操作:VoI28资讯网——每日最新资讯28at.com

  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等。VoI28资讯网——每日最新资讯28at.com

JDK命令行工具所在目录%JAVA_HOME%/bin 目录下:VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

这里你会发现这些工具的大小基本上都是17kb左右。为何?因为这些工具大部分都是VoI28资讯网——每日最新资讯28at.com

%JAVA_HOME%/bin/tools.jar这个jar中的类实现的,而这里的可执行exe文件只是对这写功能做了简单的一个封装而已。VoI28资讯网——每日最新资讯28at.com

对应到tools.jar中VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

参数:VoI28资讯网——每日最新资讯28at.com

-l :输出完整的包名+类名,如果执行的是jar包,输出jar包的路径。VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

-v:输出进程启动时的jvm参数。VoI28资讯网——每日最新资讯28at.com

还是以上面的测试程序为例:VoI28资讯网——每日最新资讯28at.com

启动jvm参数设置:VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

-q:只输出进程号。VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

到此jps工具介绍完毕。VoI28资讯网——每日最新资讯28at.com

2.jstat

用于监视虚拟机运行时的各种信息。如:类加载,内存,垃圾回收等信息。VoI28资讯网——每日最新资讯28at.com

使用格式:VoI28资讯网——每日最新资讯28at.com

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

vmid:表示jvm进程号。VoI28资讯网——每日最新资讯28at.com

interval:表示查询间隔(单位秒 s,毫秒 ms)。VoI28资讯网——每日最新资讯28at.com

count:表示查询次数VoI28资讯网——每日最新资讯28at.com

查看option有哪些选项信息(也就是可以监控哪些信息)VoI28资讯网——每日最新资讯28at.com

命令:VoI28资讯网——每日最新资讯28at.com

jstat -options

图片图片VoI28资讯网——每日最新资讯28at.com

-class: 显示类加载,卸载的数量,总空间及加载所耗时。VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

-compiler:显示JIT编译器编译过的方法,耗时等信息。VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

-gc:监视Java堆的使用情况,GC时间等信息。VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

S0C:第一个幸存区的大小VoI28资讯网——每日最新资讯28at.com

S1C:第二个幸存区的大小VoI28资讯网——每日最新资讯28at.com

S0U:第一个幸存区的使用大小VoI28资讯网——每日最新资讯28at.com

S1U:第二个幸存区的使用大小VoI28资讯网——每日最新资讯28at.com

EC:伊甸园区的大小VoI28资讯网——每日最新资讯28at.com

EU:伊甸园区的使用大小VoI28资讯网——每日最新资讯28at.com

OC:老年代大小VoI28资讯网——每日最新资讯28at.com

OU:老年代使用大小VoI28资讯网——每日最新资讯28at.com

MC:方法区大小VoI28资讯网——每日最新资讯28at.com

MU:方法区使用大小VoI28资讯网——每日最新资讯28at.com

CCSC:压缩类空间大小VoI28资讯网——每日最新资讯28at.com

CCSU:压缩类空间使用大小VoI28资讯网——每日最新资讯28at.com

YGC:年轻代垃圾回收次数VoI28资讯网——每日最新资讯28at.com

YGCT:年轻代垃圾回收消耗时间VoI28资讯网——每日最新资讯28at.com

FGC:老年代垃圾回收次数VoI28资讯网——每日最新资讯28at.com

FGCT:老年代垃圾回收消耗时间VoI28资讯网——每日最新资讯28at.com

GCT:垃圾回收消耗总时间VoI28资讯网——每日最新资讯28at.com

-gcutil:该选项与-gc基本相同,但他主要关注的是已使用空间占总空间的百分比。VoI28资讯网——每日最新资讯28at.com

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

-gcnew:监视年轻代GC情况。VoI28资讯网——每日最新资讯28at.com

VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

图片VoI28资讯网——每日最新资讯28at.com

-gcold:监视老轻代GC情况。VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

示例:VoI28资讯网——每日最新资讯28at.com

jstat -gc 16480 3s

每3秒统计一次gc信息。VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

3. jinfo

实时查看和调整虚拟机各项参数。VoI28资讯网——每日最新资讯28at.com

使用:VoI28资讯网——每日最新资讯28at.com

jinfo option pid

示例:
输出当前jvm进程的完整信息
VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

查询具体jvm参数值信息:VoI28资讯网——每日最新资讯28at.com

jinfo -flag CICompilerCount 16480

4. jmap

用于生成堆转储快照信息。VoI28资讯网——每日最新资讯28at.com

使用格式:VoI28资讯网——每日最新资讯28at.com

jmap [option] pid

option参数说明:VoI28资讯网——每日最新资讯28at.com

-dump:生成Java堆转储快照VoI28资讯网——每日最新资讯28at.com

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

示例:VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

-heap:显示Java堆详细信息。如:使用的垃圾回收期,参数配置,分代信息等。VoI28资讯网——每日最新资讯28at.com

jmap -heap <pid>

示例:VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

-histo:显示堆中对象的统计信息,包括类,实例数,合计容量等。VoI28资讯网——每日最新资讯28at.com

jmap -histo <pid>

示例:VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

5. jhat

堆转储文件分析工具。
VoI28资讯网——每日最新资讯28at.com

使用格式:VoI28资讯网——每日最新资讯28at.com

jhat <file>

分析上面生成的文件VoI28资讯网——每日最新资讯28at.com

示例:VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

6. jstack

用于生成当前进程中当前时刻线程的快照。VoI28资讯网——每日最新资讯28at.com

使用格式:VoI28资讯网——每日最新资讯28at.com

jstack [option] <pid>

参数:VoI28资讯网——每日最新资讯28at.com

-F:当正常输出的请求不被响应时,强制输出线程堆栈。VoI28资讯网——每日最新资讯28at.com

-l:除了显示堆栈信息,还显示关于锁的相关信息。VoI28资讯网——每日最新资讯28at.com

-m:如果调用的是本地方法,可以显示C/C++的堆栈。VoI28资讯网——每日最新资讯28at.com

示例:VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

图片图片VoI28资讯网——每日最新资讯28at.com

完毕!!!VoI28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-12736-0.html【JVM问题排查】JDK命令行工具详解,这四个工具你都会用吗?

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 喝了100杯酱香拿铁,我开窍了

下一篇: 困在分支迷宫?Git分支管理大对决 Git Flow vs GitHub Flow

标签:
  • 热门焦点
  • 一加Ace2 Pro真机揭晓 钛空灰配色质感拉满

    终于,在经过了几波预热之后,一加Ace2 Pro的外观真机图在网上出现了。还是博主数码闲聊站曝光的,这次的外观设计还是延续了一加11的方案,只是细节上有了调整,例如新加入了钛空灰
  • 红魔电竞平板评测:大屏幕硬实力

    前言:三年的疫情因为要上网课的原因激活了平板市场,如今网课的时代已经过去,大家的生活都恢复到了正轨,这也就意味着,真正考验平板电脑生存的环境来了。也就是面对着这种残酷的
  • 7月安卓手机性能榜:红魔8S Pro再夺榜首

    7月份的手机市场风平浪静,除了红魔和努比亚带来了两款搭载骁龙8Gen2领先版处理器的新机之外,别的也想不到有什么新品了,这也正常,通常6月7月都是手机厂商修整的时间,进入8月份之
  • 学习JavaScript的10个理由...

    作者 | Simplilearn编译 | 王瑞平当你决心学习一门语言的时候,很难选择到底应该学习哪一门,常用的语言有Python、Java、JavaScript、C/CPP、PHP、Swift、C#、Ruby、Objective-
  • 梁柱接棒两年,腾讯音乐闯出新路子

    文丨田静 出品丨牛刀财经(niudaocaijing)7月5日,企鹅FM发布官方公告称由于业务调整,将于9月6日正式停止运营,这意味着腾讯音乐长音频业务走向消亡。腾讯在长音频领域还在摸索。为
  • 新电商三兄弟,“抖快红”成团!

    来源:价值研究所作 者:Hernanderz 随着内容电商的概念兴起,抖音、快手、小红书组成的&ldquo;新电商三兄弟&rdquo;成为业内一股不可忽视的势力,给阿里、京东、拼多多带去了巨大压
  • 三星获批量产iPhone 15全系屏幕:苹果史上最惊艳直屏

    按照惯例,苹果将继续在今年9月举办一年一度的秋季新品发布会,有传言称发布会将于9月12日举行,届时全新的iPhone 15系列将正式与大家见面,不出意外的话
  • AMD的AI芯片转单给三星可能性不大 与台积电已合作至2nm制程

    据 DIGITIMES 消息,英伟达 AI GPU 出货逐季飙升,接下来 AMD MI 300 系列将在第 4 季底量产。而半导体业内人士表示,近日传出 AMD 的 AI 芯片将转单给
  • iQOO 11S新品发布会

    iQOO将在7月4日19:00举行新品发布会,推出杭州亚运会电竞赛事官方用机iQOO 11S。
Top