Jmeter 使用详解、性能压测分析与性能优化思路
背景
辣鸡公司,测试人员都没有,新开发的接口需要做性能测试,只能由开发人员来做了。我上一次用Jmeter还是大三时学《软件测试》糊里糊涂弄的,都没玩明白。哎,欠的迟早要还,于是恶补了一下性能测试的知识与Jmeter的使用方法。这可能不是写得最好的Jmeter文档,但一定是非常细致的。 本文适用于完全不会用jmeter或使用步骤不清晰的小伙伴快速上手,不适用于大佬级别查漏补缺。
下载
可以直接到jmeter官方地址下载,点击一下图中框框的地方就可以弹出下载了。文件大小80多m,下载速度基本维持在200多kb,建议先下载。
运行
jmeter是免安装的,下载后解压,进入bin
目录下,双击jmeter.bat
即可运行图形界面。
框架搭建
- 语言设置
jmeter默认语言为英语,若要修改可在 Options -> Choose Language -> Chinese(Simplified) 中改成中文。但是,我并不推荐这么做。每次重启jmeter都会变回来英文,与其设置不如适应。在文中我也会以英文界面作为教程。
- 创建线程组
右键TestPlan
的字体区域(空白区域无效),点击 add -> Threads(Users) -> Thread Group
这样就出现了一个线程组,这是用来控制请求的并发数的。详细设置往下看,当前只做框架搭建。
- 右键
Thread Group
,选择 Add -> Sampler -> HTTP Request
层级上出来了HTTP Request,用于配置接口信息 - 右键
HTTP Request
,选中 Add -> Assertions -> Response Assertion
这是断言判断机制,目前添加的是响应断言,用于判断返回结果是成功还是失败。 - 右键
HTTP Request
,选中 Add -> Config Element -> HTTP Header Manager
添加请求头配置,如果不做这一步,请求报文中的参数将会无法以正确的格式解析。 - 右键
HTTP Request
,选中 Add -> Listener -> View Results Tree
用于查看结果响应报文是否正确 - 右键
HTTP Request
,选中 Add -> Listener -> Summary Report
用于查看总体性能信息 - 完整框架结构类似于此
补充请求信息
1. HTTP Request 信息补充
参考于下面我的配置,都比较简单,和使用postman差不多。需要注意的时候,传参时,Body Data与Parameters只能二选一。下图所示使用的是Body Data,直接配置json格式报文即可。
2. HTTP Header Manager信息补充
需要配置Content-Type与Connection 否则会无法识别上面Body Data中传输的报文
3. 配置Response Assertion
响应断言,用于区分系统出错的报文
这里选择的Not代表,当系统收到下面配置的报文之后,将其识别成响应出错。复制一段错误报文后,在Patterns to Test 栏目下,点击Add,将报文粘贴进去。或者直接点击Add from clipboard。
连通性测试
配置信息都已经完成了,接下来先要测试是否能访问通接口。在Thread Group中,先配置发送一个请求,如果一开始没改过的话,这里应该不用改
点击执行
随后到 View Results Tree中,查看结果。可以看到案例中,我的系统访问是通畅的。
图中我的响应报文的应该被归类到错误里的,但是结果却显示了访问成功,jmeter默认判断Response code 为200即表示访问成功。这就是响应断言没做好,应该要把这段报文添加到Response Assertion中。
开始测试
确保接口访问无误后,开始进行性能测试。先将Thread Properties中的配置调整一下,可参考于我的配置,这里的配置的含义是不间断并发5个,你可以理解成发了5个请求后又立马发送5个请求这样。先点击clear all 再点击run,否则前面的统计结果会影响了本次执行的结果统计。
我们关心的数据,主要是有红框的内容
- 执行时间:性能压测一般都会持续一段时间,如10分钟
- Samples:这个表示已发送请求的数量
- Average:平均响应时间
- Error % :系统出错率,前提是响应断言一定要做好
- Throughput:吞吐量,单接口的情况下,吞吐量非常接近于tps,这个是非常重要的参考数据
性能监控
在持续压测到一定时间后,tps趋于稳定状态,这个时候需要考虑加压。加压并不是说随便加,加到返回来一大堆error就是对了。需要考虑服务器的cpu与内存的占用率,一般而言,cpu占用率与内存占用率不建议超过80%,一方面是运维设置的阈值,一方面是机器性能到了80%就容易出错。
如果是linux服务器,可通过top命令查看,用100 - id 的数值就是当前cpu的占用率
如果是windows系统,打开cmd,执行resmon
调整线程数量(users),同时监控cpu占用率,当cpu占用率到达近80%时,停止调整
持续压测,等待tps的变动趋于稳定后,这就是接口的性能数据了。
性能优化
若前面的压测结果不符合你的预期,需要优化性能,应该着重考虑如下几点
1. 数据库慢查询语句检查与索引优化 (有所提升)
2. 加入缓存 (非常显著)
3. 日志优化(非常显著)
日志等级调整为INFO,debug级别会对性能有较大的影响。
4. 若上述方案都无法解决的话,则需要配合工具来检查具体的慢线程
jconsole、arthas、nmon
Jmeter 使用详解、性能压测分析与性能优化思路相关推荐
- 软件性能测试分析与调优实践之路-JMeter对RPC服务的性能压测分析与调优-手稿节选
一.JMeter 如何通过自定义Sample来压测RPC服务 RPC(Remote Procedure Call)俗称远程过程调用,是常用的一种高效的服务调用方式,也是性能压测时经常遇到的一种服务调用 ...
- sysbench性能压测以及mysql性能压测
sysbench性能压测以及mysql性能压测 一.Sysbench是一个模块化的.跨平台.多线程基准测试工具,主要用于各种不同系统的参数下的数据库负载情况. 主要测试方式 cpu性能 磁盘io性能 ...
- RocketMQ性能压测分析(转载)
一 机器部署 1.1 机器组成 1台nameserver 1台broker 异步刷盘 2台producer 2台consumer 1.2 硬件配置 CPU 两颗x86_64cpu,每颗cp ...
- 性能测试 性能测试实战(八)Jmeter性能测试平台开发,性能测试平台架构解析 ,性能测试平台搭建 分布式性能压测平台 Jmeter分布式性能测试管理平台 性能测试平台示例案例 《完结篇》
文章目录 一.前言 二.Jmeter分布式性能测试平台 介绍 1.Jmter分布式性能测试平台 简介 2.Jmeter分布式性能测试平台 优秀案例1 3.Jmeter分布式性能测试平台 优秀案例2 4 ...
- 性能压测工具选型对比
本文是<Performance Test Together>(简称PTT)系列专题分享的第二期,该专题将从性能压测的设计.实现.执行.监控.问题定位和分析.应用场景等多个纬度对性能压测的全 ...
- 压测接口线程数设置_ZAT掌门性能压测巡检系统实战和落地
项目背景 随着业务拓展,对于接口性能的要求也在上升,各部门也开始针对部分慢接口进行优化,从测试角度针对这些优化需求进行测试时不仅要保证对应接口的功能正常使用同时也要验证接口优化成果.在日常的开发工作中 ...
- Dubbo之HTTP RPC vs Dubbo RPC性能压测
公司内部的RPC框架,经过长时间的发展,已经由完全自研演进到底层替换为Dubbo实现,但使用方式(API)还是不变.由于使用了PB序列化协议,以及业务码+操作码定义接口的方式,非常影响开发效率,可理解 ...
- 软件测试 | Jmeter 性能测试工具的实战应用《接口性能压测》的操作步骤详解
嘿.大家好,我是4U: 接口测试可以提前发现软件bug,有效地降低软件的开发成本,而接口性能压测也可以达到同样的效果.如果形容LR是大炮,那么JM则是一把狙击步枪. 那么今天我们来讲讲接口性能压测. ...
- sysbench数据库性能压测详解
文章目录 0.参考资料&适用范围 1.安装 2.压测 2.1.CPU压测 2.2.MySQL数据库压测 2.2.1.选项说明 2.2.2.压测步骤 0.参考资料&适用范围 参考资料: ...
- tcp压测工具_【解决方案】性能压测及分析调优实践
[关键导读]结合一次重保活动的性能压测需求,详解了整体的性能测试策略及性能分析思路,并在实施过程中有效利用了网易易测的NPT性能测试平台一站式完成了压测场景设计.执行.业务指标监控.性能指标分析等活动 ...
最新文章
- MapInfo中常用查询函数及用法
- 多个ViewPager引发的Fragment未初始化
- 【 SIMULATION 】RMSE Comparison of Linear Approaches for TOA - Based Positioning
- 系统相机裁剪比例_《零基础轻松学会PS》二章第3节:裁剪工具的使用方法
- 理解一下select 1 和 exists
- python中提供怎样的内置库、可以用来创建用户界面_使用外部GUI库在Autodesk中创建用户界面可能会...
- 2.6 Word2Vec
- Linux内核中Makefile、Kconfig和.config的关系
- WampServer2.0的Apache的service无法启动的解决方法
- unitywebplayer 32/64 5.3版本
- oracle sql列转行_oracle 行转列 列转行 转载
- 在表格中显示形位公差符号
- 微波遥感原理(武汉大学出版社2003年6月30号 舒宁《微波遥感原理》)
- 英语问题,(有些答案不对,不对的请说一声)
- 台式计算机拆解与安装,台式机固态硬盘安装流程拆解
- 公积金能付首付吗?你在公积金贷款买房前这些知道吗?
- 观光公交削弱_削弱Web开发人员和Internet的7大障碍
- 查看 Linux 进程 巧用ps|grep命令
- matlab 椭圆方程拟合
- java 程序员相关网址合集收藏
热门文章
- linux 在 vi 中设定一下行号 怎么做啊 求图片,linux中vi/vim显示行号设置
- 批量打印远端PDF文件
- 无盘服务器架设之一:编译iPXE,用于网络,ISO,USB等无盘启动
- Codeforces 633C Spy Syndrome 2(Trie+暴力)
- ubuntu18.04通过deb文件安装软件
- 使用google doc制作在线问卷调查表
- git commit --amend 的使用记录
- 基于RabbitMQ实现的订单超时功能-记录备查
- 超赞的新浪短网址链接生成器推荐(附t.cn短链接缩短api接口)
- 怎样才能写好一份高质量的市场需求文档(MRD)