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

前言:

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

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

回车后终端显示为: 

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

  • 输入的命令参数

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

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

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

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

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

扫描二维码关注公众号,回复: 9377174 查看本文章

接下来就可以看到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++的堆栈
发布了36 篇原创文章 · 获赞 46 · 访问量 7878

猜你喜欢

转载自blog.csdn.net/weixin_41860630/article/details/87655066