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++的堆栈 |