性能分析之使用 Jvisualvm dump 分析示例

2024-08-31 01:28

本文主要是介绍性能分析之使用 Jvisualvm dump 分析示例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、前言

在 JMeter 入门系列中相信大家对工具使用已经没问题,今天开起性能测试进阶系列之 jvisualvm 工具简单学习,目标是通过演示 Jvisualvm 工具定位代码,帮助性能测试工程师直接定位代码位置,协助开发解决性能问题;

前置条件:

  • 1、本机 JDK 并且工具包中有 Jvisualvm
  • 2、本机安装JMeter
  • 3、本机能运行 idea 或者能运行 Demo 代码

二、线程状态

常见的线程状态为如下:
在这里插入图片描述

了解上面信息后,打开idea编写简单代码如下:

@GetMapping("/7d")
@ResponseBody
public R indexPage() {HashMap<String, Object> map = new HashMap<>();map.put("success", "欢迎来到性能实战课堂");return R.ok().put("data", map);
}
/*** 运行线程** @return*/
@GetMapping("/runnable")
@ResponseBody
public R runnable() {List<MemberEntity> list = pageIndexService.selectAll();return R.ok().put("data", list);
}
/*** 运行线程** @return*/
@GetMapping("/sleep")
@ResponseBody
public R sleep() {List<MemberEntity> list = pageIndexService.selectSleepAll();return R.ok().put("data", list);
}

启动工程:
在这里插入图片描述

访问如下:
在这里插入图片描述

三、JMeter与Jvisualvm

打开 JMeter 并且编写脚本成功如下:
在这里插入图片描述

打开 Jvisualvm 工具选择自己启动的工程:
在这里插入图片描述

即可看到当前系统配置,点击线程标签如下图,再点击时间线标签即可按名称排序,在这里问一个问题,为什么 http-nio-8080 线程数是10个,大家可以思考下,不知道的也没关系,继续往下学习,答案会揭晓。
在这里插入图片描述
查看配置文件:application.properties 输入server.tomcat.threads-min-spare就能看的默认参数是10。
在这里插入图片描述
这个参数是否是刚才看到的线程数,咱们可以修改为5,启动工程,点击线程如下:

在这里插入图片描述
小伙伴们你们猜对了吗?如果猜对恭喜你们可以开始开启 jar 微服务工程性能参数调优,如果没有猜对的希望通过这次学习后知道怎么修改参数,目前很多工程还是tomcat工程,想问一个问题就是默认 tomcat 参数在什么地方修改,这个大家可以自己想一想在什么地方修改。

源码位置如下:
在这里插入图片描述
在这里插入图片描述

四、Jvisualvm代码定位

  • 第一步:Jmeter 压力持续执行,目的方便定位代码
  • 第二步:打开 Jvisualvm 工具点击线程结果如下:
    在这里插入图片描述
    通过上面线程可以看出目前线程开始运行,线程只有运行情况下才会消耗CPU,点击监视即可看到相关资源消耗如:
    在这里插入图片描述
    更换Jmeter请求,并且继续执行Jmeter:
    在这里插入图片描述

打开 jvisualvm 发现大量线程在 sleep 如图,大家可以想一想下一步应该做,在这一讲中主要讲解通过现象定位到代码行中,其实在做性能测试过程中,线上环境很少能用这样的工具操作一般会直接通过命令打dump之后把文件下载到本地进行分析,在线上因为会消耗性能,但是在测试环境或者对于性能学习使用工具定位能力还是需要。

如果不会分析可以学习**《性能测试实战30讲》之06丨倾囊相授:我毕生所学的性能分析思路都在这里了**
在这里插入图片描述
看的现象是slepp,点击dump,看线程找到自己工程的包,再看代码在做什么业务,导致目前线程在sleep状态中:
在这里插入图片描述
通过上面dump定位发现线程处于TIMED_WAITING (sleeping) ;

在这里插入图片描述
上面箭头数字表示目前代码行数,打开工程对比是否定位到代码行如:

在这里插入图片描述

通过dump的线程直接定位代码行数,剩下的就是分析业务代码逻辑进行代码调优。

五、线程阅读方法

选择一段线程:
在这里插入图片描述

查看方法是: 线程调用逻辑是从下往上看

在提出第一行进行分析:

"http-nio-8080-exec-4" #209 daemon prio=5 os_prio=31 tid=0x00007fdd7927f000 nid=0x7203 waiting on condition [0x000070000f277000]
  • 线程名称:“http-nio-8080-exec-4”
  • 线程优先级:prio=5
  • 线程对应的本地线程id号:nid=0x7203
  • 线程的状态:waiting
  • 线程占用内存地址 [0x000070000f277000]

打开idea 生成 Sequence Diagram 生成如下图:
在这里插入图片描述

通过这个图应该就明白他们调用关系,想起左老师一句话 “一图胜千句”。

六、总计

通过简单一个案例让大家快速通过 jvisualvm 工具定位到代码,在做性能测试过程中掌握几个常用工具能快速解决问题也是不错。

这篇关于性能分析之使用 Jvisualvm dump 分析示例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1122489

相关文章

Python常用命令提示符使用方法详解

《Python常用命令提示符使用方法详解》在学习python的过程中,我们需要用到命令提示符(CMD)进行环境的配置,:本文主要介绍Python常用命令提示符使用方法的相关资料,文中通过代码介绍的... 目录一、python环境基础命令【Windows】1、检查Python是否安装2、 查看Python的安

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

Python中help()和dir()函数的使用

《Python中help()和dir()函数的使用》我们经常需要查看某个对象(如模块、类、函数等)的属性和方法,Python提供了两个内置函数help()和dir(),它们可以帮助我们快速了解代... 目录1. 引言2. help() 函数2.1 作用2.2 使用方法2.3 示例(1) 查看内置函数的帮助(

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

C++ 函数 strftime 和时间格式示例详解

《C++函数strftime和时间格式示例详解》strftime是C/C++标准库中用于格式化日期和时间的函数,定义在ctime头文件中,它将tm结构体中的时间信息转换为指定格式的字符串,是处理... 目录C++ 函数 strftipythonme 详解一、函数原型二、功能描述三、格式字符串说明四、返回值五

LiteFlow轻量级工作流引擎使用示例详解

《LiteFlow轻量级工作流引擎使用示例详解》:本文主要介绍LiteFlow是一个灵活、简洁且轻量的工作流引擎,适合用于中小型项目和微服务架构中的流程编排,本文给大家介绍LiteFlow轻量级工... 目录1. LiteFlow 主要特点2. 工作流定义方式3. LiteFlow 流程示例4. LiteF

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.