JMeter尝鲜
最近打算对一个线上HTTP接口做下压力测试,选择JMeter做为压测工具。
关于JMeter
Apache JMeter是Apache组织开发的基于Java的压力测试工具。可以用于对静态的和动态的资源(文件,Servlet,Perl脚本,java 对象,数据库和查询,FTP服务器等等)的性能进行测试。可以用于对服务器、网络或对象模拟繁重的负载来测试它们的强度或分析不同压力类型下的整体性能。你可以使用它做性能的图形分析或在大并发负载测试你的服务器/脚本/对象。
官网:http://jmeter.apache.org/download_jmeter.cgi
环境准备
- 安装Java环境。我机器上的是JAVA1.8版本。
- JMeter下载,我下载的版本为5.2.1,解压后无需安装直接可以使用的。进入bin目录,双击
jmeter.bat
即可启动一个CMD窗口和一个GUI界面。
注意图片红圈的警告,意思就是:不要使用GUI运行压力测试,GUI仅用于压力测试的创建和调试;执行压力测试请不要使用GUI。使用下面的命令来执行测试
jmeter -n -t [jmx file] -l [results file] -e -o [Path to web report folder]
并且修改JMeter批处理文件的环境变量:HEAP="-Xms1g -Xmx1g -XX:MaxMetaspaceSize=256m"
测试计划-创建线程组
在测试计划右键 【添加】-->【线程(用户)】-->【线程组】。
设置线程数=300;Ramp-Up时间=5;循环次数=永远。
这里解释下,
Ramp-Up
默认0,表示如果启动后,300个线程会立即启动执行。设置一个时间后,线程数会分批启动执行。主要是为了保护服务端,不要被瞬间击穿。
循环次数
这里我选择的是永远,不代表真的是永远,这里表示线程会一直执行下去。后续的会设置停止条件。通常这里可以选择持续时间,或者循环几次。
测试计划-设置HTTP请求默认值
在线程组上右键 【添加】-->【配置元件】-->【HTTP请求默认值】。
设置协议=http;服务器/IP=你的服务域名/IP地址。
测试计划-创建HTTP请求取样器
在线程组上右键 【添加】-->【取样器】-->【HTTP请求】。
设置HTTP请求 方法=POST;路径=你的服务路径,注意上面已经设置了HTTP默认服务器,所以这里只需要设置相对路径;内容编码=utf-8;
请求参数选择【消息体数据】,输入:
{
"id": "${id}",
"Bid":"${Bid}",
"IP":"${IP}",
"Port":"${Port}",
"UniqueID":"${UniqueID}",
"DomainName":"${DomainName}",
"ProductType":"${ProductType}",
"Version":"${Version}",
"DeviceType":"${DeviceType}"
}
这里我们是Json传输对象,选择动态参数化,所以value是 "${xx}" 格式,会和后面的数据样本对应起来。
测试计划-设置HTTP请求Head
在HTTP请求上右键 【添加】-->【配置元件】-->【HTTP信息头管理器】。
添加接口所需要的Head头,包括接口认证授权等等。这样所有的HTTP请求都会自动添加Head。
测试计划-参数化请求数据
在HTTP请求上右键 【添加】-->【配置元件】-->【CSV数据文件设置】。
这里的文件我们使用的是.txt格式。具体格式如下,对应着上面HTTP请求参数化设置。
id,Bid,IP,Port,UniqueID,DomainName,ProductType,Version,DeviceType
1234567891011123,E35B2798-DBA0-47F3-9194-47CF21F91E32,10.205.11.11,80,10.205.11.11,test.passport.com,test,V2.0,Iphone
1234567891011124,E35B2798-DBA0-47F3-9194-47CF21F91E32,10.205.11.11,80,10.205.11.11,test.passport.com,test,V2.0,Iphone
1234567891011125,E35B2798-DBA0-47F3-9194-47CF21F91E32,10.205.11.11,80,10.205.11.11,test.passport.com,test,V2.0,Iphone
1234567891011126,E35B2798-DBA0-47F3-9194-47CF21F91E32,10.205.11.11,80,10.205.11.11,test.passport.com,test,V2.0,Iphone
1234567891011127,E35B2798-DBA0-47F3-9194-47CF21F91E32,10.205.11.11,80,10.205.11.11,test.passport.com,test,V2.0,Iphone
配置设置:
遇到文件结束符再次循环=False
;遇到文件结束符号停止线程=True
,限定了线程运行终结条件。线程共享模式=所有现场
表示所有线程依次从数据文件中读取每行数据,保证了数据不会重复请求执行。还有其他选择当前线程组
、当前线程
可以依字面意思理解。
测试计划-设置监听器
在线程组上右键 【添加】-->【监听器】-->【察看观察树】、【聚合报告】。
结果树会记录每个请求的执行情况;聚合报告则是对执行结果的分析,一般这个就是我们要的压测结果数据。简单解释下各个字段的意思。
- 样本:压测执行的HTTP请求总数
- 平均值:平均每个HTTP请求耗时,单位毫秒
- 中位数:按执行时间排序,排在中间的请求耗时,单位毫秒。
- 90%百分位:90%的请求耗时不超过该时间
- 95%百分位:95%的请求耗时不超过该时间
- 99%百分位:99%的请求耗时不超过该时间
- 最小值&最大值:请求耗时的最小值和最大值
- 异常%:请求错误的请求数%。这项通常需要特别关注。服务端压力正常是不应该有异常。错误的标准可以在
- 吞吐量:即每秒请求数。这个就是我们要的数据啦~~
- 接收/发送:网络数据统计,单位KB/s
遇到的问题
到这里压测计划完成了,可以保存倒 ***.jmx 文件。拿到生产环境上,将线程数设置倒500运行了一下。
执行命令行
jmeter -n -t MyPlans/QueryInvits.jmx -l Report/query.csv -e -o Report/htmlreport_query
结果发现 异常% 40%,检查请求日志,发现大量的异常:
HTTP请求,Non HTTP response code: java.net.BindException,Non HTTP response message: Address already in use: connect,confirminvitations
请求并没有打到服务端,在压测客户端已经失败了。网上搜查了下,是由于windows端口被耗尽了(默认1024-5000)。有以下几种解决方式:
- 修改操作系统注册表,找到
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\TCPIP\Parameters
,新建 DWORD值,name:MaxUserPort,value:65534(十进制),然后重启系统。 - 将HTTP请求改成短链接(去掉 使用 keepAlive 的勾)。
我这里选择的是第二种方式,并且将线程数也缩小倒300个,再次执行,顺利完成,异常%=0。
分布式压测
到这里,实际还并没有完成所有压测的需求。由于上面的问题,我们知道单机压测的瓶颈实际上在压测客户端,单机并不能模拟大量多线程(用户)来发起大量的并发请求,所以我们还需要多机器分布式来支持压测。
笔者之前采用的是笨笨的手工动分离数据+手动多机执行+手动数据汇总的方式~~~ 其实JMeter也支持该功能。
这里参考:https://www.cnblogs.com/UncleYong/p/10854152.html
JMeter尝鲜的更多相关文章
- Windows 10 周年版尝鲜
早在今年的 Build 大会上,微软就开始宣传最新的 Windows 10 周年版更新,炫了不少特技,直到昨天(2016/8/2 PST)才正式放出,相关新闻可以参考这里,正式的版本为 Version ...
- 【翻译】五步快速使用LINQPad尝鲜StreamInsight
StreamInsight 学习地址:http://www.cnblogs.com/StreamInsight/archive/2011/10/26/StreamInsight-Query-Seri ...
- 小程序新能力-个人开发者尝鲜微信小程序
个人开发者的福利 微信小程序,刚听到这个新名词的时候,我就兴冲冲的去找入口,看看自己能不能搞个微信小程序的HelloWorld,毕竟能在微信上把自己写的一些小工具跑起来还是满炫酷的. 没想,网上一查, ...
- 【响应式】foundation栅格布局的“尝鲜”与“填坑”
提到响应式,就不得不提两个响应式框架--bootstrap和foundation.在标题上我已经说明白啦,今天给大家介绍的是foundation框架. 何为"尝鲜"?就是带大伙 ...
- Spring-Data-JPA尝鲜:快速搭建CRUD+分页后台实例
前言:由于之前没有接触过Hibernate框架,但是最近看一些博客深深被它的"效率"所吸引,所以这就来跟大家一起就着一个简单的例子来尝尝Spring全家桶里自带的JPA的鲜 Spr ...
- 微信团队分享:Kotlin渐被认可,Android版微信的技术尝鲜之旅
本文由微信开发团队工程是由“oneliang”原创发表于WeMobileDev公众号,内容稍有改动. 1.引言 Kotlin 是一个用于现代多平台应用的静态编程语言,由 JetBrains 开发( ...
- Linux下尝鲜IDE Rider .NET又一开发利器
RiderRS 扯淡:很多人说:jetbrains出品,必属精品,jetbrains确实出了不少好东西,但是他的产品总感觉越用越慢,我的小Y430P高配版也倍感压力,内存占用率高. Multiple ...
- Win10尝鲜体验——初识传说中不一样的Windows 分类: 资源分享 2015-07-24 18:27 13人阅读 评论(0) 收藏
这几天,网上传来一个消息,虽然不知是好是坏,Win10可以下载安装了! 出于好奇,下载尝鲜,几个截图,留作纪念~ 中文,还是要好好支持的,毕竟中国有如此多的用户 可选的安装版本 许可条款也刚刚出炉,估 ...
- 微信小程序“满月”:尝鲜之后你还用过它吗?
距离 2017 年 1 月 9 日微信小程序上线,整整过去了一个月时间.和互联网时代每天出现的众多新鲜事物相似,小程序甫一诞生,立即占据了各大科技媒体网站头屏并引起社交圈的兴奋讨论.由于背靠微信,纷纷 ...
随机推荐
- IntelliJ IDEA 控制台输出中文乱码
IntelliJ IDEA 控制台输出中文乱码部分如图所示: 解决方法一: 1.打开IntelliJ IDEA本地安装目录中bin文件夹下的idea.exe.vmoptions和idea64.exe. ...
- IDEA生成MyBatis文件
IDEA 逆向 MyBatis 工程时,不像支持 Hibernate 那样有自带插件,需要集成第三方的 MyBatis Generator. MyBatis Generator的详细介绍 http:/ ...
- Spring 基于注解的 IOC 配置
创建 spring 的 的 xml 配置 文件 <context:component-scan base-package="com.itheim"/> 指定创建容器时要 ...
- python7.1处理异常
a=[21,32,43,0,32,"a"]for i in a:#取出元素 try:#写可能会报错的代码 print(3/i) except Exception as e:#捕获t ...
- JavaScript按位运算符~
1. JavaScript按位运算符 Bit operators work on 32 bits numbers. 2. JavaScript按位运算符~ 值得注意的是,在JavaScript中,~5 ...
- 理解JavaScript的原型链
1. 什么是对象 在JavaScript中,对象是属性的无序集合,每个属性存放一个原始值.对象或函数. 1.1 创建对象 在JavaScript中创建对象的两种方法: ① 字面上: var myObj ...
- 常见排序算法原理及JS代码实现
目录 数组 sort() 方法 冒泡排序 选择排序 插入排序 希尔排序 归并排序 堆排序 快速排序 创建时间:2020-08-07 本文只是将作者学习的过程以及算法理解进行简单的分享,提供多一个角度的 ...
- 导航菜单(动画)--- jQuery
本文章实现是一个导航菜单的功能 (1)点击当前菜单显示二级菜单,再次点击收起当前菜单. (2)当有一个二级菜单显示,点击其他菜单,上一个已点击菜单会收起.只展示当前点击的菜单,只显示一个菜单,类似手风 ...
- C++输出错误信息perror、strerror以及全局变量errno
头文件:#include<stdio.h>函数:perror.strerror,全局变量:errno.使用方法: FILE *fp; if((fp = fopen("test.t ...
- 2020-06-20:一句话总结ZK?
福哥答案2020-06-20: 这道题价值不大,但是面试题里有这道题. 分布式协调服务,注册服务和发现,树形结构,监听机制,过半机制. ZooKeeper是源代码开放的分布式协调服务,由雅虎公司创建, ...