JDK命令行工具详解「问题排查」

环境:JDK1.8.0_92

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

JDK命令行工具详解「问题排查」

 

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

%JAVA_HOME%\bin\tools.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工具介绍完毕。


  1. 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基本相同,但他主要关注的是已使用空间占总空间的百分比。

JDK命令行工具详解「问题排查」

 

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命令行工具详解「问题排查」

 


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

使用:

jinfo option pid

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

JDK命令行工具详解「问题排查」

 

查询具体jvm参数值信息:

jinfo -flag CICompilerCount 16480


  1. 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命令行工具详解「问题排查」

 


  1. jhat
    堆转储文件分析工具。

使用格式:jhat <file>

分析上面生成的文件

示例:

JDK命令行工具详解「问题排查」

 

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

JDK命令行工具详解「问题排查」

 


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

使用格式:

jstack [option] <pid>

参数:

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

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

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

示例:

JDK命令行工具详解「问题排查」

 

JDK命令行工具详解「问题排查」

 

完毕!!!

给个关注+转发谢谢

SpringBoot项目中异步调用接口方式知多少?

 

SpringBoot项目中异步调用接口方式知多少?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值