环境:JDK1.8.0_92BF428资讯网——每日最新资讯28at.com
JDK(Java Development Kit)提供了一系列的命令行工具,用于帮助开发人员进行问题排查。以下是关于JDK命令行工具问题排查的一些常见操作:BF428资讯网——每日最新资讯28at.com
- 使用jps查看虚拟机进程:jps是一个用于显示Java虚拟机(JVM)进程信息的工具。通过jps指令可以获取到正在运行的JVM进程的ID(PID),这对于后续的问题排查非常有用。
- 使用jstat监视虚拟机运行时信息:jstat是一个用于监视虚拟机运行时各种信息的工具。它可以监控类加载数量、内存使用情况、垃圾回收情况等信息,对于排查内存泄漏、GC问题等非常有用。
- 使用jstack获取线程堆栈信息:jstack是一个用于获取Java线程堆栈信息的工具。当JVM进程出现异常或卡顿时,可以使用jstack指令获取线程堆栈信息,以帮助开发人员找到问题所在。
- 使用jmap生成堆转储文件:jmap是一个用于生成Java堆转储文件的工具。当JVM内存溢出或需要排查内存问题时,可以使用jmap指令生成堆转储文件,以帮助开发人员找到内存泄漏或垃圾回收等问题。
以上是JDK命令行工具问题排查中常用的几个操作,它们可以帮助开发人员快速定位和解决问题。当然,还有其他JDK提供的工具也可以用于问题排查,例如jconsole、jvisualvm等。BF428资讯网——每日最新资讯28at.com
JDK命令行工具所在目录%JAVA_HOME%/bin 目录下:BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
这里你会发现这些工具的大小基本上都是17kb左右。为何?因为这些工具大部分都是BF428资讯网——每日最新资讯28at.com
%JAVA_HOME%/bin/tools.jar这个jar中的类实现的,而这里的可执行exe文件只是对这写功能做了简单的一个封装而已。BF428资讯网——每日最新资讯28at.com
对应到tools.jar中BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
接下来对常用的工具做介绍:BF428资讯网——每日最新资讯28at.com
1.jps
显示所有当前正在运行的HosSpot虚拟机进程。BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
参数:BF428资讯网——每日最新资讯28at.com
-l :输出完整的包名+类名,如果执行的是jar包,输出jar包的路径。BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
-m:输出启动程序时,传的参数信息。BF428资讯网——每日最新资讯28at.com
测试程序:BF428资讯网——每日最新资讯28at.com
public class JpsMain { public static void main(String[] args) throws Exception { System.out.println(Arrays.toString(args)) ; System.in.read() ; }}
启动参数设置:BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
启动时设置了3个参数分别是:a , b , cBF428资讯网——每日最新资讯28at.com
查看:BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
-v:输出进程启动时的jvm参数。BF428资讯网——每日最新资讯28at.com
还是以上面的测试程序为例:BF428资讯网——每日最新资讯28at.com
启动jvm参数设置:BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
查看:BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
-q:只输出进程号。BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
到此jps工具介绍完毕。BF428资讯网——每日最新资讯28at.com
2.jstat
用于监视虚拟机运行时的各种信息。如:类加载,内存,垃圾回收等信息。BF428资讯网——每日最新资讯28at.com
使用格式:BF428资讯网——每日最新资讯28at.com
jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]]
vmid:表示jvm进程号。BF428资讯网——每日最新资讯28at.com
interval:表示查询间隔(单位秒 s,毫秒 ms)。BF428资讯网——每日最新资讯28at.com
count:表示查询次数BF428资讯网——每日最新资讯28at.com
查看option有哪些选项信息(也就是可以监控哪些信息)BF428资讯网——每日最新资讯28at.com
命令:BF428资讯网——每日最新资讯28at.com
jstat -options
图片BF428资讯网——每日最新资讯28at.com
-class: 显示类加载,卸载的数量,总空间及加载所耗时。BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
-compiler:显示JIT编译器编译过的方法,耗时等信息。BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
-gc:监视Java堆的使用情况,GC时间等信息。BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
S0C:第一个幸存区的大小BF428资讯网——每日最新资讯28at.com
S1C:第二个幸存区的大小BF428资讯网——每日最新资讯28at.com
S0U:第一个幸存区的使用大小BF428资讯网——每日最新资讯28at.com
S1U:第二个幸存区的使用大小BF428资讯网——每日最新资讯28at.com
EC:伊甸园区的大小BF428资讯网——每日最新资讯28at.com
EU:伊甸园区的使用大小BF428资讯网——每日最新资讯28at.com
OC:老年代大小BF428资讯网——每日最新资讯28at.com
OU:老年代使用大小BF428资讯网——每日最新资讯28at.com
MC:方法区大小BF428资讯网——每日最新资讯28at.com
MU:方法区使用大小BF428资讯网——每日最新资讯28at.com
CCSC:压缩类空间大小BF428资讯网——每日最新资讯28at.com
CCSU:压缩类空间使用大小BF428资讯网——每日最新资讯28at.com
YGC:年轻代垃圾回收次数BF428资讯网——每日最新资讯28at.com
YGCT:年轻代垃圾回收消耗时间BF428资讯网——每日最新资讯28at.com
FGC:老年代垃圾回收次数BF428资讯网——每日最新资讯28at.com
FGCT:老年代垃圾回收消耗时间BF428资讯网——每日最新资讯28at.com
GCT:垃圾回收消耗总时间BF428资讯网——每日最新资讯28at.com
-gcutil:该选项与-gc基本相同,但他主要关注的是已使用空间占总空间的百分比。BF428资讯网——每日最新资讯28at.com
S0:幸存1区当前使用比例S1:幸存2区当前使用比例E:伊甸园区使用比例O:老年代使用比例M:元数据区使用比例CCS:压缩使用比例YGC:年轻代垃圾回收次数FGC:老年代垃圾回收次数FGCT:老年代垃圾回收消耗时间GCT:垃圾回收消耗总时间
-gcnew:监视年轻代GC情况。BF428资讯网——每日最新资讯28at.com
BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
-gcold:监视老轻代GC情况。BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
示例:BF428资讯网——每日最新资讯28at.com
jstat -gc 16480 3s
每3秒统计一次gc信息。BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
3. jinfo
实时查看和调整虚拟机各项参数。BF428资讯网——每日最新资讯28at.com
使用:BF428资讯网——每日最新资讯28at.com
jinfo option pid
示例:
输出当前jvm进程的完整信息BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
查询具体jvm参数值信息:BF428资讯网——每日最新资讯28at.com
jinfo -flag CICompilerCount 16480
4. jmap
用于生成堆转储快照信息。BF428资讯网——每日最新资讯28at.com
使用格式:BF428资讯网——每日最新资讯28at.com
jmap [option] pid
option参数说明:BF428资讯网——每日最新资讯28at.com
-dump:生成Java堆转储快照BF428资讯网——每日最新资讯28at.com
jmap -dump:live,format=b,file=heap.bin <pid>
示例:BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
-heap:显示Java堆详细信息。如:使用的垃圾回收期,参数配置,分代信息等。BF428资讯网——每日最新资讯28at.com
jmap -heap <pid>
示例:BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
-histo:显示堆中对象的统计信息,包括类,实例数,合计容量等。BF428资讯网——每日最新资讯28at.com
jmap -histo <pid>
示例:BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
5. jhat
堆转储文件分析工具。
BF428资讯网——每日最新资讯28at.com
使用格式:BF428资讯网——每日最新资讯28at.com
jhat <file>
分析上面生成的文件BF428资讯网——每日最新资讯28at.com
示例:BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
这里生成了一个端口为7000的服务,直接访问BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
6. jstack
用于生成当前进程中当前时刻线程的快照。BF428资讯网——每日最新资讯28at.com
使用格式:BF428资讯网——每日最新资讯28at.com
jstack [option] <pid>
参数:BF428资讯网——每日最新资讯28at.com
-F:当正常输出的请求不被响应时,强制输出线程堆栈。BF428资讯网——每日最新资讯28at.com
-l:除了显示堆栈信息,还显示关于锁的相关信息。BF428资讯网——每日最新资讯28at.com
-m:如果调用的是本地方法,可以显示C/C++的堆栈。BF428资讯网——每日最新资讯28at.com
示例:BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
图片BF428资讯网——每日最新资讯28at.com
完毕!!!BF428资讯网——每日最新资讯28at.com
本文链接:http://www.28at.com/showinfo-26-12736-0.html【JVM问题排查】JDK命令行工具详解,这四个工具你都会用吗?
声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com
上一篇: 喝了100杯酱香拿铁,我开窍了
下一篇: 困在分支迷宫?Git分支管理大对决 Git Flow vs GitHub Flow