本节将会介绍一下jvisualvm的特性及作用、各个功能是如何使用的、最后会介绍jvisualvm的插件Visual GC的安装及使用。
目录
jvisualvm介绍
jvisualvm使用介绍
Visual GC插件安装及使用
VisualVM(All-in-One Java Troubleshooting Tool)是到目前为止随JDK发布的功能最强大的运行监视和故障处理程序,它提供了运行监视、故障处理、性能分析(Profiling)等功能。VisuaIVM有一个很大的优点:不需要被监视的程序基于特殊Agent运
行,因此它对应用程序的实际性能的影响很小,使得它可以直接应用在生产环境中。
jdk8的文档中https://docs.oracle.com/javase/8/docs/technotes/tools/unix/index.html就有jvisualvm的使用介绍,
jvisualvm的官网介绍地址为:https://docs.oracle.com/javase/8/docs/technotes/guides/visualvm/index.html 。
VisualVM基于NetBeans平台开发,因此它一开始就具备了插件扩展功能的特性,通过插件扩展支持,visualVM可以做到:
VisualvM可以监控本地和远程的Java应用程序,可能会有部分功能在监控远程应用程序时无法使用。在jdk安装目录\bin的命令中找到jvisualvm.exe双击打开即可使用。
打开jvisualvm后,可以看到如下界面,其可以监控本地和远程的Java应用程序,图中红框圈住的是本地程序,左侧显示的com.wkp.jvm.ServiceapiApplication (pid 8700)其实相当于 jps -l 命令的输出。可以看到有概述、监视、线程、抽样器和Profiler这几个功能菜单,而Visual GC是添加的插件,默认是没有的(下面会介绍这个插件)。
1、概述里面显示了JDK的版本、PID、JVM参数、系统属性等(相当于java -version,jps,jinfo等命令)。
Java应用程序如果想能够远程连接监控,可以通过JMX和jstatd,如果使用JMX则启动时要添加JMX相关的参数(具体的远程连接感兴趣的话,可以自己找文章看一下哈):
nohup java -jar -Djava.rmi.server.hostname=192.168.74.4 -Dcom.sun.management.jmxremote.port=1099 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false test.jar &
2、监视菜单,可以看到如下界面:展示了CPU使用情况、堆内存大小及占用情况、类的装载和线程情况。点击堆Dump按钮会生成堆dump文件,相当于jmap命令。
双击打开上面生成的dump文件,可以看到如下所示:点击显示线程信息会看到线程dump信息(跟jstack命令输出的一样),然后还有类、实例数和OQL控制台,这个和前面介绍的MAT类似。
点击类按钮,会看到如下所示:可以看到类的实例数、大小等,还有一个重要功能"与另一个堆存储进行比较",
可以在执行GC前后分别产生堆dump文件,然后进行对比分析哪些对象有了变化、是如何变化的。
3、线程菜单, 可以看到所有的线程信息:线程数量、线程状态、线程名称、线程运行时间等,点击线程Dump按钮会跟jstack命令一样生成线程dump文件。
4、抽样器菜单,点击“CPU”按钮启动一个 CPU 性能分析会话 ,VisualVM 会检测应用程序所有的被调用的方法。当进入一个方法时,线程会发出一个“method entry”的事件,当退出方法时同样会发出一个“method exit”的事件,这些事件都包含了时间戳。然后 VisualVM 会把每个被调用方法的总的执行时间和调用的次数按照运行时长展示出来。
此外,我们也可以通过性能分析结果下方的方法名过滤器对分析结果进行过滤。
点击抽样器中的内存会看Java程序中的类的实例数、线程分配的内存等信息。
5、Profiler分析器:跟上面的抽样器类似,也可以选择CPU或者内存进行监控,这里就不贴图了。
如果你是通过双击jvisualvm.exe打开的,则在你点击Profiler中的CPU或者内存的时候会出现 VisualVm的Profiler一直转圈:正在连接到目标VM,解决方式就是通过命令启动,并且添加启动参数即可解决。
jvisualvm -J-Dorg.netbeans.profiler.separateConsole=true //-J即表示JVM OPTION:允许带JVM参数启动
C:\Program Files\java8\jdk1.8.0_112\bin>jvisualvm -J-Dorg.netbeans.profiler.separateConsole=true
点击Profiler中的CPU会显示方法的执行时间、调用次数等
点击Profiler中的内存会对内存进行分析,会显示分配的对象,对象的大小,对象的年龄等信息。
jvisulaVM如何添加插件:https://visualvm.github.io/index.html,visual GC插件下载地址为:https://visualvm.github.io/pluginscenters.html,根据自己的jdk版本选择对应的插件版本,并复制插件下载链接
点击VisualVm的工具->插件,开始的时候可能可用插件显示为0,可用在设置里面添加,把上面的链接地址复制进去,确定之后可用插件列表里面就可以看到了。在可用插件列表中选中,然后点击安装,安装完成后重启即可看到Visual GC插件。
打开Visual GC插件可以看到整个区域分为三部分:spaces、graphs、histogram
1,spaces区域:代表虚拟机内存分布情况。从图中可以看出,虚拟机被分为Metaspace、Old、Eden、S0、S1
2,Graphs区域:内存使用详细介绍
3,histogram:显示survivor区域对象的年龄
Visual GC的histogram可能会显示不受此JVM支持,因为是垃圾收集器的原因,Java应用默认使用UseParallelGC 并行收集器,这时候是不显示的,不用并行收集器就可以了,例如改为CMS+Parnew就能正常显示。