你知道高并发的性能测试怎么做吗?
作者:lovesoo
blog.csdn.net/lovesoo/article/details/78579547
1. Jmeter简介
Apache JMeter是一款纯java编写负载功能测试和性能测试开源工具软件。相比Loadrunner而言,JMeter小巧轻便且免费,逐渐成为了主流的性能测试工具,是每个测试人员都必须要掌握的工具之一。
本文为JMeter性能测试完整入门篇,从Jmeter下载安装到编写一个完整性能测试脚本、最终执行性能测试并分析性能测试结果。
运行环境为Windows 10系统,JDK版本为1.8,JMeter版本为3.3。
2. Jmeter安装
2.1 JDK安装
由于Jmeter是基于java开发,首先需要下载安装JDK (目前JMeter只支持到Java 8,尚不支持 Java 9)
1.官网下载地址:
http://www.oracle.com/technetwork/java/javase/downloads/index.html
2.选择Java SE 8u151/ 8u152,点击JDK下载
3.安装下载的JDK
4.配置系统环境变量
推荐:100道Java中高级面试题汇总+详细拆解
2.2 JMeter安装
1.官网下载地址:
http://jmeter.apache.org/download_jmeter.cgi
2.下载最新JMeter 3.3版本:apache-jmeter-3.3.zip
3.下载完成后解压zip包
4.启动JMeter
双击JMeter解压路径(apache-jmeter-3.3\bin)bin下面的jmeter.bat即可
3. 测试实例
我们选取最常见的百度搜索接口:
3.1 接口地址
http://www.baidu.com/s?ie=utf-8&wd=jmeter性能测试
3.2 请求参数
ie:编码方式,默认为utf-8
wd: 搜索词
3.3 返回结果
搜索结果,我们可以通过校验结果中是否含有搜索词wd来判断本次请求成功或失败。
4. JMeter脚本编写
4.1 添加线程组
右键点击“测试计划” -> “添加” -> “Threads(Users)” -> “线程组”
这里可以配置线程组名称,线程数,准备时长(Ramp-Up Period(in seconds))循环次数,调度器等参数:
线程组参数详解:
线程数:虚拟用户数。一个虚拟用户占用一个进程或线程。设置多少虚拟用户数在这里也就是设置多少个线程数。
Ramp-Up Period(in seconds)准备时长:设置的虚拟用户数需要多长时间全部启动。如果线程数为10,准备时长为2,那么需要2秒钟启动10个线程,也就是每秒钟启动5个线程。
循环次数:每个线程发送请求的次数。如果线程数为10,循环次数为100,那么每个线程发送100次请求。总请求数为10*100=1000 。如果勾选了“永远”,那么所有线程会一直发送请求,一到选择停止运行脚本。
Delay Thread creation until needed:直到需要时延迟线程的创建。
调度器:设置线程组启动的开始时间和结束时间(配置调度器时,需要勾选循环次数为永远)
持续时间(秒):测试持续时间,会覆盖结束时间
启动延迟(秒):测试延迟启动时间,会覆盖启动时间
启动时间:测试启动时间,启动延迟会覆盖它。当启动时间已过,手动只需测试时当前时间也会覆盖它。
结束时间:测试结束时间,持续时间会覆盖它。
因为接口调试需要,我们暂时均使用默认设置,待后面真正执行性能测试时再回来配置。
4.2 添加HTTP请求
右键点击“线程组” -> “添加” -> “Sampler” -> “HTTP请求”
对于我们的接口http://www.baidu.com/s?ie=utf-8&wd=jmeter
性能测试,可以参考下图填写:
Http请求主要参数详解:
1.Web服务器
协议:向目标服务器发送HTTP请求协议,可以是HTTP或HTTPS,默认为HTTP
服务器名称或IP :HTTP请求发送的目标服务器名称或IP
端口号:目标服务器的端口号,默认值为80
2.Http请求
方法:发送HTTP请求的方法,可用方法包括GET、POST、HEAD、PUT、OPTIONS、TRACE、DELETE等。
路径:目标URL路径(URL中去掉服务器地址、端口及参数后剩余部分)
Content encoding :编码方式,默认为ISO-8859-1编码,这里配置为utf-8
3.同请求一起发送参数
在请求中发送的URL参数,用户可以将URL中所有参数设置在本表中,表中每行为一个参数(对应URL中的 name=value),注意参数传入中文时需要勾选“编码”
4.3 添加察看结果树
右键点击“线程组” -> “添加” -> “监听器” -> “察看结果树”
这时,我们运行Http请求,修改响应数据格式为“HTML Source Formatted”,可以看到本次搜索返回结果页面标题为”jmeter性能测试_百度搜索“。
4.4 添加用户自定义变量
我们可以添加用户自定义变量用以Http请求参数化,右键点击“线程组” -> “添加” -> “配置元件” -> “用户定义的变量”:
新增一个参数wd,存放搜索词:
并在Http请求中使用该参数,格式为:${wd}
4.5 添加断言
右键点击“HTTP请求” -> “添加”-> “断言” -> “响应断言”
我们校验返回的文本中是否包含搜索词,添加参数${wd}
到要测试的模式中:
4.6 添加断言结果
右键点击“HTTP请求” -> “添加”-> “监听器” -> “断言结果”
这时,我们再运行一次就可以看到断言结果成功或失败了
4.7 添加聚合报告
右键点击“线程组” -> “添加” -> “监听器” -> “聚合报告”,用以存放性能测试报告
这样,我们就完成了一个完整Http接口的JMeter性能测试脚本编写。
5. 执行性能测试
5.1 配置线程组
点击线程组,配置本次性能测试相关参数:线程数,循环次数,持续时间等,这里我们配置并发用户数为10,持续时间为60s
5.2 执行测试
点击绿色小箭头按钮即可启动测试,测试之前需要点击小扫把按钮清除之前的调试结果。
6. 分析测试报告
待性能测试执行完成后,打开聚合报告可以看到:
聚合报告参数详解:
Label:每个 JMeter 的 element(例如 HTTP Request)都有一个 Name 属性,这里显示的就是 Name 属性的值
#Samples:请求数——表示这次测试中一共发出了多少个请求,如果模拟10个用户,每个用户迭代10次,那么这里显示100
Average:平均响应时间——默认情况下是单个 Request 的平均响应时间,当使用了 Transaction Controller 时,以Transaction 为单位显示平均响应时间
Median:中位数,也就是 50% 用户的响应时间
90% Line:90% 用户的响应时间
Min:最小响应时间
Max:最大响应时间
Error%:错误率——错误请求数/请求总数
Throughput:吞吐量——默认情况下表示每秒完成的请求数(Request per Second),当使用了 Transaction Controller 时,也可以表示类似 LoadRunner 的 Transaction per Second 数
KB/Sec:每秒从服务器端接收到的数据量,相当于LoadRunner中的Throughput/Sec
一般而言,性能测试中我们需要重点关注的数据有:#Samples 请求数,Average 平均响应时间,Min 最小响应时间,Max 最大响应时间,Error% 错误率及Throughput 吞吐量。推荐:100道Java中高级面试题汇总+详细拆解
7. 源码下载
至此,我们使用JMeter完成了一个完整的Http接口性能测试流程,从脚本编写,执行到最终结果分析。
完整的脚本源码下载链接:
https://pan.baidu.com/s/1eS90cVo 密码: st15
END
精彩推荐
一百期Java面试题汇总
SpringBoot内容聚合
IntelliJ IDEA内容聚合
Mybatis内容聚合
我知道你 “在看”
你知道高并发的性能测试怎么做吗?相关推荐
- 面试官:高并发的性能测试做过吗?
点击上方"后端技术精选",选择"置顶公众号" 技术文章第一时间送达! 作者:lovesoo blog.csdn.net/lovesoo/article/deta ...
- 千万别说做过高并发!
懂高并发性能调优,一定是你在技术进阶赛道变得牛逼的加分项.不论,你是开发,架构还是管理岗,亦或者是其他互联网相关岗位. 因为毫不夸张的说,在现在动辄过千万级的并发流量环境下,懂得并发压测.性能瓶颈诊断 ...
- 如何掌握java多线程,高并发,大数据方面的技能?
https://www.zhihu.com/question/27575123 如何掌握java多线程,高并发,大数据方面的技能? 因为想进入互联网公司,然后发现互联网类型的公司问的主要问题都离不开这 ...
- 面试官绝杀:系统是如何支撑高并发的?
作者 | 中华石杉 责编 | 伍杏玲 很多人面试的时候被问到一个让人特别手足无措的问题:你的系统如何支撑高并发? 大多数同学被问到这个问题压根儿没什么思路去回答,不知道从什么地方说起,其实本质就是没经 ...
- 如何设计一个高并发系统
人人都开始聊高并发,高并发,那么所谓的高并发到底应该是啥,应该怎么理解这个高并发这个概念呢?这么说来就得要思考为啥会产生高并发? 简单来说,因为我们从传统的单体项目开始系统都是需要直接连接数据库的,而 ...
- 面试官,再也别问我的系统如何支持高并发了
1.一道面试题的背景引入 这篇文章,我们聊聊大量同学问我的一个问题,面试的时候被问到一个让人特别手足无措的问题:你的系统如何支撑高并发? 大多数同学被问到这个问题压根儿没什么思路去回答,不知道从什么地 ...
- 想设计亿万级高并发架构,你要先知道高并发是什么?
当前,数字化在给企业带来业务创新,推动企业高速发展的同时,也给企业的IT软件系统带来了严峻的挑战.面对流量高峰,不同的企业是如何通过技术手段解决高并发难题的呢? 0.引言 软件系统有三个追求:高性能. ...
- thinkphp mysql高并发_WBB - ThinkPhp高并发提交如何保障数据正常
高并发导致的数据错误 通常出现于多连接,假设当前用户余额为100. A逻辑从数据库取值得到100,扣取50,得到50,进行数据库保存.最终数据库=50. 在同一瞬间内,A逻辑未保存数据库前,B逻辑从数 ...
- 500并发 一台服务器的性能_面试官绝杀:系统是如何支撑高并发的?
作者 | 中华石杉 责编 | 伍杏玲 本文经授权转载石杉的架构笔记(ID:shishan100) 很多人面试的时候被问到一个让人特别手足无措的问题:你的系统如何支撑高并发? 大多数同学被问到这个问题压 ...
最新文章
- 云计算学习(3-3)云计算的由来-应运而生
- AI:人工智能概念之机器学习中常用算法的思维导图集合(非常经典、建议收藏)之详细攻略
- server端推送消息机制
- HTML5汽车轮毂改装网站模板
- Illustrator中文版教程,如何在 Illustrator 中使用自由变换工具?
- linux log4j 使用
- 怎么修改背景图片大小的HTML代码,网页背景图片的大小的代码是什么
- t.cn短链接是怎么生成的?
- 编程语言的宗教狂热和十字军东征 (转)
- m4s格式转换mp3_视频怎么转换成音频MP3格式
- python爬虫下载小说
- 电子书如何通过邮箱传入kindle
- 为什么网络安全缺口很大,而招聘却很少?
- Android studio修改标题菜单栏增加功能图标(navigation bar toolbar)
- 实用食品英语 (餐桌上用的)
- 关于九宫格的一个算法,求大神助攻
- 瑜伽健身培训报名约课小程序开发制作介绍
- readFile读取文件
- 软考A计划-试题模拟含答案解析-卷十一
- Mysql 8的四种隔离级别以及对应不同类型的锁