Java虚拟机性能监控工具介绍

前言:

    由于笔者使用的是MacOS系统,并且我们可能会忘记JDK安装到哪个目录下,所以在这里先简单的介绍一下MacOS系统如何找到JDK安装目录的。

    首先,打开终端,并在终端输入:/usr/libexec/java_home -V。(注意:V一定要是大写的)

回车后终端显示为: 

上图中由上到下的三个红框框起来的内容依次为:

  • 输入的命令参数

  • Mac上已经安装的JDK版本和路径(如果存在多个版本会全部显示)

  • Mac上默认使用的jdk安装路径路径

接下来是如何前往这个路径:

  • 打开find-->前往-->前往文件夹-->输入以上路径—>点击回车

  • 或者shift+command+G 直接到“前往文件夹”-->输入以上路径—>点击回车

 

接下来就可以看到JDK的bin目录啦,如下图所示:

首先介绍JDK主要命令行监控工具及其用途:

名称主要作用
jps显示指定系统内所有的HotSpot虚拟机进程
jstat用于收集HotSpot虚拟机各方面运行的数据
jinfo显示虚拟机配置信息
jmap生成虚拟机的内存转储存快照(heapdump文件)
jhat用于分析heaodump文件,它会建立一个HTTP/HTML服务器,让用户可以在浏览器上查看分析结果
jstack显示虚拟机的线程快照

 

逐个示范以上工具

1.jps:虚拟机进程状况工具

jsp执行样例:

打开终端,输入jsp,显示如下:

同理,如果要查看指定的信息,则输入下表中(jps的其他常用选项)的参数即可。这里暂不做演示,大家可以自行尝试。

jps的其他常用选项如下表:

选项作用
-q只输出LYMID,省略主类的名称
-m输出虚拟机进程启动时传递给主类main()函数的参数
-l输出主类的全名,如果进程执行的是Jar包,输出Jar路径
-v输出虚拟机进程启动时JVM参数

 

2.jstat:虚拟机统计信息监视工具

在没有GUI图形界面,只提供了纯文本控制台环境的服务器上,它将是运行期定位虚拟机性能问题的首选工具。

jstat执行样例:

假设需要每250毫秒查询间隔和次数,如果省略这两个参数,说明只查询一次。假设需要每250毫秒查询一次进程(对应进程)垃圾收集的情况,一共查询20次,那命令应该是:

jstat -gc (进程数) 250 20

下图中框起的部分分别代表进程数,以及查询命令,之下是20次查询的结果。

对于希望查询的虚拟机信息总共分为三类:类装载、垃圾收集和运行编译状况。具体使用可以参照下表(jstat的其他常用选项):

jstat的其他常用选项如下表:

选项 
-class监视类装载、卸载数量、总空间及类装载所耗费的时间
-gc监视Java堆状况,包括Eden区、2个survivor区、老年代、永久代等的容量、已用空间、GC时间合计等信息
-gccapacity监视内容与-gc基本相同,但输出主要关注Java堆各个区域使用到的最大和最小空间
-gcutil监视内容与-gc基本相同,但输出主要关注已使用空间占总空间的百分比
-gccause与-gcutil功能一样,但是会额外输出导致上一次GC产生的原因
-gcnew监视新生代GC的情况
-gcnewcapacity监视内容与-gcnew基本相同,输出主要关注使用到的最大空间和最小空间
-gcold监视老年代GC的情况
-gcoldcapacity监视内容与-gcold基本相同,输出主要关注使用到的最大空间和最小空间
-compiler输出JIT编译器编译过的方法、耗时等信息
-printcompilation输出已经被JIT编译的方法

3.jinfo:Java配置信息工具

jinfo的作用是实时地查看和调整虚拟机的各项参数。

使用jsp -v可以查看虚拟机启动时显示指定的参数列表,但如果想知道未被显示指定的参数的系统默认值,只能使用jinfo的-flag选项进行查询。

jinfo还可以使用-sysprops选项把虚拟机进程的System.getProperties()内容打印出来。

4.jmap:Java内存映像工具

jmap命令用于生成堆转储快照(一般称为heapdump或dump文件)。

jmap还可以查询finalize执行队列,java堆和永久代的详细信息,如空间使用率、当前用的是哪种收集器等。

jmap的其他常用选项如下表:

选项作用
-dump生成Java堆转储快照。格式为:-dump:[live,]format=b,file=<filename>,其中live子参数说明是否只dump出存活的对象
-finalizerinfo显示在F-Queue中等待Finalizer线程执行finalize方法的对象。只在Linux/Solaris平台下有效
-heap显示Java堆详细信息,如使用哪种回收器、参数配置、分代状况等。只在Linux/Solaris平台下有效
-histo显示堆中对象统计信息,包括类、实例数量和合计容量
-permstat以ClassLoader为统计口径显示永久代内存状态。只在Linux/Solaris平台下有效
-F当虚拟机进程对-dump选择没有响应时,可使用这个选项强制生成dump快照。只在Linux/Solaris平台下有效

5.jhat:虚拟机堆转储快照分析工具

jhat用来搭配jmap使用,用来分析dump文件。但是,一般不会这么使用,因为现在已经有很多可视化工具来分析dump文件,功能能强大。

6.jstack:Java堆栈跟踪工具

jstack命令用于生成虚拟机当前时刻的线程快照。

jstack的其他常用选项如下表:

选项作用
-F当正常输出的请求不被响应时,强制输出线程堆栈
-l除堆栈外,显示关于锁的附加信息
-m如果调用到本地方法的话,可以显示C/C++的堆栈

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值