JVM系列(十三) -常用调优工具介绍

news2024/12/25 1:22:59

最近对 JVM 技术知识进行了重新整理,再次献上 JVM系列文章合集索引,感兴趣的小伙伴可以直接点击如下地址快速阅读。

  • JVM系列(一) -什么是虚拟机
  • JVM系列(二) -类的加载过程
  • JVM系列(三) -内存布局详解
  • JVM系列(四) -对象的创建过程
  • JVM系列(五) -对象的内存分配流程
  • JVM系列(六) -运行期优化技术
  • JVM系列(七) -垃圾收集算法
  • JVM系列(八) -垃圾收集器
  • JVM系列(九) -GC日志分析
  • JVM系列(十) -常用调优命令汇总
  • JVM系列(十一) -常用调优工具介绍
  • JVM系列(十二) -常用调优参数总结

一、摘要

在之前的文章中,我们介绍了 JVM 常用的命令使用,通过这些命令可以快速的查询线上服务的性能情况和排查相关的问题。

不错,命令确实非常的管用,但是要想熟悉的记住这些命令,并非易事,除非很频繁的使用,否则真的很难。多数情况下,如果代码编程合理,服务器配置合理,服务也没有高并发压力,开发人员基本上很少会去关注 JVM 相关性能情况。

因此,对于绝大部分开发者而言,都希望有一个可视化的界面来展示当前服务的性能指标,当需要的时候,直接将线上服务的 dump 文件导出,然后导入到相关工具中通过界面来查询分析结果,而不是通过枯燥的命令来快速排查服务故障。

下面我们就一起来看看几款比较优秀的 JVM 可视化分析工具。

二、JDK 自带的工具

2.1、jconsole

jconsole 是一款 JDK 自带的可视化监控工具,可以用于查看应用程序的运行概况、内存、线程、类、VM 概括、MBean 等信息。它是一个基于 JMX(java management extensions)的 GUI 性能监测工具,从 JDK1.5 开始加入。

2.1.1、启动方式

在命令行输入jconsole即可启动。如果 Windows 用户,也可以在 jdk 的安装目录的 bin 目录下,找到jconsole.exe,双击启动。界面如下。

可以直接选择本地 JVM,也可以通过 JMX 方式连接远程 JVM。

如果监控远程服务,比如 tomcat 服务,可以在启动脚本中添加如下代码,以便支持远程连接。

-Dcom.sun.management.jmxremote.port=6969  
 -Dcom.sun.management.jmxremote.ssl=false  
 -Dcom.sun.management.jmxremote.authenticate=false

点击连接之后,可能会弹出如下的界面,选择“不安全的连接”即可。

进入之后,就可以看到 jconsole 概览图和主要的功能,例如概述、内存、线程、类、VM、MBean 等板块。概览界面如下。

2.1.2、内存板块

内存板块主要展示了内存的使用情况,同时可以查看堆和非堆内存的变化值对比,也可以点击执行 GC 来触发 GC 的执行。界面如下。

2.1.3、线程板块

线程板块主要展示线程数的活动数和峰值,点击左下方线程可以查看线程的详细信息,比如线程的状态是什么,堆栈内容等,同时也可以点击“检测死锁”来检查线程之间是否有死锁的情况。界面如下。

2.1.4、类板块

类板块主要展示已加载的类数量。界面如下。

2.1.5、VM 概要板块

VM 概要板块主要展示 JVM 所有信息总览,包括基本信息、线程相关、堆相关、操作系统、VM 参数等。界面如下。

2.1.6、MBean 板块

MBean 板块主要展示被管理的 Bean 的属性,方法等。界面如下。

2.2、VisualVM

VisualVM 也是一款 JDK 自带的可视化监控工具,利用它不仅能够监控服务的 CPU、内存、线程、类等信息,还可以捕获有关 JVM 软件实例的数据,并将该数据保存到本地系统,以供后期查看或与其他用户共享,从 JDK1.6 开始加入。

与此同时,VisualVM 使用也很简单,几乎 0 配置,功能比较丰富,几乎囊括了 JDK 自带命令的所有功能,也是平时使用最多的调优工具之一。

2.2.1、启动方式

在命令行输入jvisualvm即可启动。如果 Windows 用户,也可以在 jdk 的安装目录的 bin 目录下,找到jvisualvm.exe,双击启动。界面如下。

可以直接选择本地 JVM,也可以远程连接 JVM。这里选择本地 JVM 进程,双击某个进程即可打开。

进入之后,就可以看到 VisualVM 相关的展示界面,例如概述、监视、线程、抽样器等板块。概述界面如下。

2.2.2、监视板块

监视板块主要展示 cpu、内存、线程、类的统计图表,也支持手动执行垃圾回收和生成堆 Dump 文件。界面如下。

点击“堆 Dump”按钮之后,就会生成一份当前时刻的堆文件快照,在界面上可以查询当前文件的对象大小分析结果。界面如下。

同时还支持与另一个堆文件进行比较,展示差异信息。界面如下。

2.2.3、线程板块

线程板块主要展示线程的活动数。界面如下。

点击“线程 Dump”按钮之后,就会生成一份当前时刻的线程快照,在界面上可以查询线程的状态。界面如下。

2.2.4、抽样器板块

抽样器板块可以对 CPU、内存在一段时间内进行数据抽样,以供分析。界面如下。

比如,点击“CPU”按钮之后,可以实时的查询线程和方法占用 CPU 时间长短排名,点击“停止”按钮即可结束抽样。

同理,点击“内存”按钮之后,可以实时的查询堆中对象占用大小排名以及每个线程分配的内存大小排名。

2.2.5、插件安装

VisualVM 还有一大亮点,就是它支持插件安装。每个插件的关注点都不同,有的是监控 GC,有的是监控内存,有的是监控线程等,可以在插件市场上寻找对应的工具进行安装,以便更好的排查服务性能问题。

如何安装插件呢?

在 VisualVM 的菜单栏,点击“工具” -》 “插件”,便会弹出如下界面。

在“可用插件”栏中,选中需要安装的插件,点击“安装”,一路完成,最后重启 VisualVM,即可完成插件的安装。

如果获取可用插件异常,可以访问如下地址,找到对应版本范围,包含安装 JDK 版本的链接。

https://visualvm.github.io/pluginscenters.html

拷贝出对应的链接,然后在设置栏中填入对应的地址即可。

通常,我们会将 Visual GC 插件安装到 VisualVM 中,利用它可以更加直观的观察到整个垃圾回收的过程。界面如下。

三、第三方调优工具

除了 JDK 自带的 JVM 可视化分析工具之外,市场上还诞生了很多比较优秀的性能监控工具,比如下面这几款工具。

  • MAT:一款功能强大的 Java 堆内存分析器,可以用于查找内存泄漏以及查看内存消耗情况,用户可以利用 visualvm 或者是 jmap 命令生产堆文件,然后导入工具中进行分析
  • GCeasy:一款在线的 GC 日志分析器,使用起来非常方便,用户可以通过它的 web 网站导入 GC 日志,实时进行内存泄漏检测、GC 暂停原因分析、JVM 配置建议优化等功能
  • GCViewer:一款非常强大的 GC 日志可视化分析工具,功能强大而且完全免费
  • JProfiler:一款商用的性能分析利器
  • arthas:阿里开源的一款线上监控诊断工具,可以查看应用负载、内存、gc、线程等信息

在此,我们重点的介绍一下 Arthas 这款工具,因为它的功能比较全,并且文档详细。

3.1、Arthas

根据官方的介绍,Arthas(阿尔萨斯)是一款线上监控诊断产品,通过全局视角实时查看应用 load、内存、gc、线程的状态信息,并能在不修改应用代码的情况下,对业务问题进行诊断,包括查看方法调用的出入参、异常,监测方法执行耗时,类加载信息等,大大提升线上问题排查效率。

Arthas 官方地址如下!

https://arthas.aliyun.com/
3.1.1、启动方式

Arthas 的启动方式非常简单,它就是一个 jar 包,通过java -jar命令即可运行。

jar 包的下载地址如下。

https://arthas.aliyun.com/arthas-boot.jar

输入如下命令,即可启动 Arthas。

 java -jar arthas-boot.jar

启动成功后,可以看到如下界面。

意思是发现有以下几个 Java 应用服务,请选择想要监控的进程,输入前面对应的编号,就可以开启进行监控模式了。比如我输入编号 1。

进入以上这个界面,就表示应用监听成功了。

3.1.2、dashboard仪表盘

dashboard 仪表盘用于展示整体项目运行情况,可以在命令窗口输入如下命令来查看。

dashboard

回车之后,一共有三块信息,分别是线程信息、内存信息、运行时信息,界面如下。

3.1.3、thread 命令

如果我们想要具体查看某一个线程的运行情况,可以使用 thread 命令。例如查询线程 Id 为16的运行状态信息,命令如下。

thread 16

还可以通过如下命令,查询所有的线程信息。

thread -all

3.1.4、jad 命令

某些时候我们想要查询线上的源码是否正确发布,可以通过 jad 命令来反编译类,以此来查询源码信息,例如反编译Application类,命令如下。

jad com.example.boot.Application

3.1.5、watch 命令

某些场景下我们想要观察某个方法的返回结果,以便判断是否符合预期效果,可以通过 watch 命令来实现,例如观察TestController类的queryAll()方法的返回结果,命令如下。

watch com.example.boot.test.web.TestController queryAll returnObj

需要前端发起请求,如果执行到这里就会有数据。输出示例结果如下。

更多的玩法,可以阅读官方文档。

四、小结

本文主要围绕 JVM 相关的可视化分析工具,进行了知识内容的整合和总结,内容比较多,如果有描述不对的地方,欢迎大家留言指出,不胜感激。

五、参考

1.http://www.ityouknow.com/jvm/2017/09/22/jvm-tool.html

2.https://arthas.aliyun.com/doc/

写到最后

最后。如果感觉文章内容不错,帮忙动动小指头点个赞,点赞对我真的非常重要!加个关注我会非常感激!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2264998.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Y3编辑器教程7:界面编辑器

文章目录 一、简介1.1 导航栏1.2 画板1.3 场景界面1.4 控件1.4.1 空节点1.4.2 按钮1.4.3 图片1.4.4 模型1.4.5 文本1.4.6 输入框1.4.7 进度条1.4.8 列表 1.5 元件1.5.1 简介1.5.2 差异说明1.5.3 元件实例的覆盖、还原与禁止操作1.5.4 迷雾控件 1.6 属性1.7 事件(动画…

重温设计模式--状态模式

文章目录 状态模式(State Pattern)概述状态模式UML图作用:状态模式的结构环境(Context)类:抽象状态(State)类:具体状态(Concrete State)类&#x…

MySQL的分析查询语句

【图书推荐】《MySQL 9从入门到性能优化(视频教学版)》-CSDN博客 《MySQL 9从入门到性能优化(视频教学版)(数据库技术丛书)》(王英英)【摘要 书评 试读】- 京东图书 (jd.com) MySQL9数据库技术_夏天又到了…

题解 洛谷 Luogu P1135 奇怪的电梯 广度优先搜索 BFS C/C++

题目传送门: P1135 奇怪的电梯 - 洛谷 | 计算机科学教育新生态https://www.luogu.com.cn/problem/P1135思路: 一道比较裸的 BFS,就是把走迷宫每次搜周围相邻四格,改成了楼层每次搜上下方向的某层而已 感觉这个题难度只有普及- …

git 删除鉴权缓存及账号信息

在Windows系统下 清除凭证管理器中的Git凭据 按下Win R键,打开“运行”对话框,输入control,然后回车,打开控制面板。在控制面板中找到“用户账户”,然后点击“凭据管理器”。在凭据管理器中,找到“Windows…

2024 高频 Java 面试合集整理 (1000 道附答案解析)

2024 年马上就快要过去了,总结了上半年各类 Java 面试题,初中级和中高级都有,包括 Java 基础,JVM 知识面试题库,开源框架面试题库,操作系统面试题库,多线程面试题库,Tcp 面试题库&am…

【图书介绍】】几本Linux C\C++编程图书

Linux C\C编程,是IT领域比较稳定的职业发展方向,本文介绍几本Linux开发方面的图书。 《Linux C与C一线开发实践(第2版)》 《Linux C与C一线开发实践(第2版)(Linux技术丛书)》(朱文…

git命令恢复/还原某个文件、删除远程仓库中的文件

有时刚创建的远程仓库,可能无意中把一些没用的文件上传到仓库,本文介绍一下怎么删除这些文件。 一、git命令恢复某个文件 第一步:拉取最新代码 git pull 第二步: 查看git 修改的文件状态 git status 第三步:查看…

shell脚本定义特殊字符导致执行mysql文件错误的问题

记得有一次版本发布过程中有提供一个sh脚本用于一键执行sql文件,遇到一个shell脚本定义特殊字符的问题,sh脚本的内容类似以下内容: # 数据库ip地址 ip"127.0.0.1" # 数据库密码 cmdbcmdb!#$! smsm!#$!# 执行脚本文件(参…

redis数据转移

可能有时候因为硬件的原因我们我们需要更换服务器,如果更换服务器的话,那我们redis的数据该怎样转移呢,按照一下步骤即可完成redis数据的转移 1.进入redis客户端 2.使用 bgsave命令进行数据的备份,此命令完成后会在你的redis安装目…

stm32引脚模式GPIO

问题引入 stm32f103定时器的引脚GPIO_MODE_OUTPUT_PP和GPIO_MODE_AF_PP有什么区别? 在STM32F103微控制器中,使用定时器时涉及到的GPIO配置主要有两种模式:GPIO_MODE_OUTPUT_PP和GPIO_MODE_AF_PP。这两种模式的主要区别在于它们的用途和工作…

Krita安装krita-ai-diffusion工具搭建comfyui报错没有ComfyUI_IPAdapter_plus解决办法

我们在使用Kirta安装krita-ai-diffusion工具之后搭建comfyui环境需要安装很多扩展文件。 一般正常安装都可以使用了。 但是有一个插件很特别,无论你安装多少遍都会显示缺失,是什么插件这么难搞定呢? 没错,就是我们的ComfyUI_IPAdapter_plus插件。 就像下图一样: 那么怎…

WordPress源码解析-数据库表结构

WordPress是一个功能强大的内容管理系统,它使用MySQL数据库来存储和管理网站的内容、用户和配置信息。作为WordPress开发者,了解WordPress数据库的结构和各表的作用至关重要,因为这将帮助您更好地开发插件和主题,以及执行高级数据…

【项目实践】SpringBoot Nacos配置管理 map数据

本文是继续上一篇博客SpringBoot使用Nacos进行application.yml配置管理_nacos application配置-CSDN博客 目录 一、踩坑记录 二、亲测成功 方法一 方法二 一、踩坑记录 参考网上的一些案例,看到网上有人建议 Nacos 可以直接配置成 Map 类型,后台使用…

XILINX平台LINUX下高速ADC08060驱动

前置调研 原理图 AXI-FULL时序 由于项目需要实时性高,采用AXI-FULL接口ADC IP作为master端写入DDR中 引用: AXI_02 AXI4总线简介(协议、时序)_axi4总线时序-CSDN博客 AXI总线的访问 在ARM架构中,访问I/O地址通常通…

【C语言】指针数组、数组指针、函数指针、指针函数、函数指针数组、回调函数

【C语言】函数指针与指针函数 文章目录 [TOC](文章目录) 前言一、指针数组二、数组指针三、函数指针四、指针函数五、函数指针数组六、回调函数七、参考资料总结 前言 使用工具: 1.DEVC 提示:以下是本篇文章正文内容,下面案例可供参考 一、…

华为IPD流程6大阶段370个流程活动详解_第二阶段:计划阶段 — 86个活动

华为IPD流程涵盖了产品从概念到上市的完整过程,各阶段活动明确且相互衔接。在概念启动阶段,产品经理和项目经理分析可行性,PAC评审后成立PDT。概念阶段则包括产品描述、市场定位、投资期望等内容的确定,同时组建PDT核心组并准备项目环境。团队培训涵盖团队建设、流程、业务…

Adversarial Machine Learning(对抗机器学习)

之前把机器学习(Machine Learning)的安全问题简单记录了一下,这里有深入研究了一些具体的概念,这里记录一下方便以后查阅。 Adversarial Machine Learning(对抗机器学习) Adversarial Examples 相关内容Eva…

UE5 猎户座漂浮小岛 12 技能 瞬移 重力控制

1. 瞬移 1.1. 显示鼠标光标 “事件开始运行”添加显示鼠标逻辑 1.2. 释放技能蓝图 设置技能键 编写蓝图 1.3. 瞬移最大距离 2. 重力控制 2.1. 添加输入与动画 映射 重定向得到动画 新增状态FIRE_GracityControl 设置动画姿势 新增变量 切换动画 2.2. 技能蓝图(…

SpiderFlow平台v0.5.0流程的执行过程

流程执行过程: 1. 流程启动 流程的执行通常从一个 开始节点 开始,该节点是整个爬虫任务的起点。开始节点没有实际的功能作用,主要作用是标记流程的起始。 执行顺序:在执行过程中,系统按照流程中的连接线顺序依次执行…