性能优化-VisualVM工具的使用

7、VisualVM工具的使用

VisualVM,能够监控线程,内存情况,查看方法的CPU时间和内存中的对 象,已被GC的对象,反向查看分配的堆栈(如100个String对象分别由哪几个对象分配出来的)。

VisualVM使用简单,几乎0配置,功能还是比较丰富的,几乎囊括了其它JDK自带命令的所有功能。

  • 内存信息
  • 线程信息
  • Dump堆(本地进程)
  • Dump线程(本地进程)
  • 打开堆Dump。堆Dump可以用jmap来生成。打开线程Dump
  • 生成应用快照(包含内存信息、线程信息等等)
  • 性能分析。CPU分析(各个方法调用时间,检查哪些方法耗时多),内存分析(各类对象占用的内存,检查哪些类占用内存多)
  • ……

7.1、启动

在jdk的安装目录的bin目录下,找到jvisualvm.exe,双击打开即可。

在这里插入图片描述
在这里插入图片描述

7.2、查看本地进程

在这里插入图片描述

7.3、查看CPU、内存、类、线程运行信息

在这里插入图片描述

7.4、查看线程详情

在这里插入图片描述
也可以点击右上角Dump按钮,将线程的信息导出,其实就是执行的jstack命令。

在这里插入图片描述
发现,显示的内容是一样的。

7.5、抽样器

抽样器可以对CPU、内存在一段时间内进行抽样,以供分析。
在这里插入图片描述

7.6、监控远程的jvm

VisualJVM不仅是可以监控本地jvm进程,还可以监控远程的jvm进程,需要借助于JMX技术实现。

7.6.1、什么是JMX?

JMX(Java Management Extensions,即Java管理扩展)是一个为应用程序、设备、系统等植入管理功能的框架。JMX可以跨越一系列异构操作系统平台、系统体系结构和网络传输协议,灵活的开发无缝集成的系统、网络和服务管理应用。

7.6.2、监控远程的tomcat

想要监控远程的tomcat,就需要在远程的tomcat进行对JMX配置,方法如下:
在这里插入图片描述
保存退出,重启tomcat。

7.6.3、使用VisualJVM连接远程tomcat

添加远程主机:
在这里插入图片描述
在一个主机下可能会有很多的jvm需要监控,所以接下来要在该主机上添加需要监控的jvm:

在这里插入图片描述

在这里插入图片描述

连接成功。使用方法和前面就一样了,就可以和监控本地jvm进程一样,监控远程的tomcat进程。

发布了1056 篇原创文章 · 获赞 888 · 访问量 3万+

猜你喜欢

转载自blog.csdn.net/weixin_42528266/article/details/103986281