前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >性能工程之Jmeter小白中级系列之一

性能工程之Jmeter小白中级系列之一

作者头像
高楼Zee
发布2021-03-16 16:14:54
发布2021-03-16 16:14:54
42600
代码可运行
举报
文章被收录于专栏:7DGroup7DGroup
运行总次数:0
代码可运行

jvisualvm简单线程定位入门

在开展今天的话题之前先引入朱熹先生的 “问渠哪得清如许,为有源头活水来” 。

一、前言

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

前置条件:

1、本机jdk并且工具包中有jvisualvm

2、本机安装Jmeter

3、本机能运行idea或者能运行Demo代码

二、线程状态

常见的线程状态为如下:

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

代码语言:javascript
代码运行次数:0
复制
@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 工具定位到代码,在做性能测试过程中掌握几个常用工具能快速解决问题也是不错。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-03-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 7DGroup 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、前言
  • 二、线程状态
  • 三、jmeter与jvisualvm
  • 四、jvisualvm代码定位
  • 五、线程阅读方法
  • 六、总计
    • 通过简单一个案例让大家快速通过 jvisualvm 工具定位到代码,在做性能测试过程中掌握几个常用工具能快速解决问题也是不错。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档