JVM监控诊断之工具使用(上篇)

Posted 编程小吉

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JVM监控诊断之工具使用(上篇)相关的知识,希望对你有一定的参考价值。

JVM监控诊断工具

使用CMD命令行工具存在以下缺陷:

🎈无法获取方法级别的分析数据,比如:方法之间的调用关系、方法的调用次数、方法的调用时间等。

🎈需要用户登录到目标Java应用程序所在的宿主机进行操作。

🎈展示的数据不够直观,很难进行理解。

1.JConsole工具

💡:JDK自带的,用于查看Java应用程序运行期间的一些有关内存、线程、类等的监控信息,是一款基于JMX的GUI性能监控工具。

  • 基本使用

  • 连接方式

    • 本地连接

      • JConsole连接一个本地正在运行的JVM,并且要求执行的应用程序和运行JConsole的用户是同一个。
      • JConsole使用文件系统的授权,通过RMI连接器连接到平台的MBean服务器上。
    • 远程连接

      使用URL通过RMI连接器连接到一个JMX代理,并且需要在环境变量中设置mx.remote.credentials来指定用户名和密码,然后进行授权访问。

    • 特殊连接

      使用一个特殊的URL来连接JMX代理,一般使用自己定制的连接器,而不是RMI提供的连接器。

  • 监控界面

    • 概览界面

    • 内存监控

    • 线程监控

    • 类的监控

    • 虚拟机监控

2.JVisualVM工具

💡:JDK自带的,用于查看Java应用程序运行期间的一些有关进程、CPU、GC、堆空间、方法区、线程等监控信息,并且支持插件,是一款功能强大且多合一的故障诊断和性能监控的GUI工具。

  • 基本使用

    也可以从官网:https://visualvm.github.io/index.html进行软件下载

  • 插件安装

    下载地址:https://visualvm.github.io/pluginscenters.html

    J Visual VM最大的特色就是支持插件扩展,我们可以通过下载离线插件文件包,然后在Plugin对话框的提示下添加已下载的插件。

    IDEA插件

  • 连接方式

    • 本地连接

      监控本地Java应用程序的进程信息

    • 远程连接

      • 首先添加JMX,通过JMX技术监控远端服务器的某个Java引用程序进程
      • 修改bin/catalina.sh文件,连接远程的tomcat
      • 在conf目录下添加jmxremote.access和jmxremote.password两个文件
      • 将服务器IP地址修改为公网IP地址
      • 设置防火墙,并启动tomcat
      • 在JMX中输入端口号、用户名、密码进行登录
  • 核心功能

    • 生成/解析堆内存快照

      生成Dump文件

      解析Dump文件

    • 生成/解析线程快照

      生成Dump文件

      解析Dump文件

    • 查看JVM参数和系统属性

    • 查看运行中的JVM进程

    • 查看程序中资源的使用

    • CPU分析和内存分析

3.JMC工具

💡:Java Mission Control,能够以极低的性能开销收集Java虚拟机上的监控数据

  • 概述

    • 它是Java官方提供的性能强劲的工具,是一个用于对Java应用程序进行管理、监视、概要分析和故障排除的工具套件。
    • 它除了拥有客户端外,还提供了一些用来收集JVM性能数据的插件,比如:JMX(用来访问存放虚拟机各个子系统运行数据的MXBeans)、JFR(Java飞行记录器)。
    • 它进行数据采样的时候,不需要进行代码植入,所以对JVM本身的影响非常小,可以用来对运行中的程序进行实时的压力测试。
  • MBean服务器功能

    • 概览信息

    • 触发器

    • 系统信息

    • 内存信息

    • 线程信息

  • 飞行记录器

    • 介绍

      • 它能够以极低的性能开销收集Java虚拟机上的性能数据
      • 它能够直接访问Java虚拟机内的数据,不会影响Java虚拟机的优化
      • 它非常适用于生产环境下满负载运行的Java程序
    • 注意事项

      在进行数据采样时,启动的Java程序需要添加如下参数:

      -XX:+UnlockCommercialFeatures
      -XX:+FlightRecorder
      

      否则将会报错:

    • 事件类型

      按照发生的时机以及持续时间来划分,JFR的事件共可分为四种类型

以上是关于JVM监控诊断之工具使用(上篇)的主要内容,如果未能解决你的问题,请参考以下文章

JVM监控诊断之工具使用(上篇)

JVM监控诊断之工具使用(上篇)

JVM监控诊断之工具使用(下篇)

JVM监控诊断之工具使用(下篇)

JVM监控诊断之工具使用(下篇)

JVM监控诊断之工具使用(下篇)