性能与压力测试——JMeter
一、常见的压力测试性能指标
- 响应时间(Response Time: RT):指用户从客户端发起一个请求开始,到客户端接收到从服务器端返回的响应结束所耗费的时间。
- HPS(Hits Per Second):每秒点击次数,单位是次/秒。
- TPS(Transaction per Second):系统每秒处理交易数,单位是笔/秒。
-
QPS(Query per Second):系统每秒处理查询次数,单位是次/秒。
对于互联网业务中,如果某些业务有且仅有一个请求连接,那么 TPS=QPS=HPS。一般情况下用 TPS 来衡量整个业务流程,用 QPS 来衡量接口查询次数,用 HPS 来表示对服务器单击请求。
无论 TPS、QPS、HPS,此指标是衡量系统处理能力非常重要的指标,越大越好,根据经验,一般情况下:
金融行业:1000TPS~50000TPS,不包括互联网化的活动
保险行业:100TPS~100000TPS,不包括互联网化的活动
制造行业:10TPS~5000TPS
互联网电子商务:10000TPS~1000000TPS
互联网中型网站:1000TPS~50000TPS
互联网小型网站:500TPS~10000TPS - 最大响应时间(Max Response Time) 指用户发出请求或者指令到系统做出反应(响应)的最大时间。
- 最少响应时间(Mininum ResponseTime) 指用户发出请求或者指令到系统做出反应(响应)的最少时间。
- 90%响应时间(90% Response Time) 是指所有用户的响应时间进行排序,第 90%的响应时间。
-
从外部看,性能测试主要关注如下三个指标:
吞吐量:每秒钟系统能够处理的请求数、任务数。
响应时间:服务处理一个请求或一个任务的耗时。
错误率:一批请求中结果出错的请求所占比例。
二、JMeter简介
Apache JMeter 是 Apache 组织基于 Java 开发的压力测试工具,用于对软件做压力测试。
1.安装启动
JMeter 依赖于JDK,所以必须确保当前计算机上已经安装了 JDK,并且配置了环境变量。
Apache Jmeter官网下载,地址:http://jmeter.apache.org/download_jmeter.cgi
解压缩即可使用,目录结构如下:
运行bin目录下的jmeter.bat脚本即可启动JMeter:
2.汉化
上面的配置只能保证本次运行是中文,如果要永久中文,需要修改 JMeter 的配置文件。打开 JMeter 文件夹,在 bin 目录中找到 jmeter.properties,添加下面配置:
language=zh_CN
3.★基本使用
-
新增线程组(用来模拟用户),填写线程信息
-
填写取样器(相当于测试的目标)内容,添加http请求
-
添加监听结果树(用来查看测试的具体结果),并察看
-
添加监听报告
汇总报告结果
4.解决JMeter在Windows下地址被占用的BUG
这个BUG是由Windows系统本身提供的端口访问机制的问题导致的。Windows 提供给 TCP/IP 链接的端口为 1024-5000,并且要四分钟来循环回收他们,这就导致我们在短时间内进行大量请求时将端口占满了。
- cmd→regedit命令打开注册表
-
在 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters 下:
- 右击 parameters,添加一个新的 DWORD,名字为 MaxUserPort;然后双击 MaxUserPort,输入数值数据为 65534,基数选择十进制(如果是分布式运行的话,控制机器和负载机器都需要这样操作哦)
-
右击 parameters,添加一个新的 DWORD,名字为 TCPTimedWaitDelay;然后双击 TCPTimedWaitDelay,输入数值数据为 30,基数选择十进制(设置回收时间为30s)
- 修改完以上配置后,重启电脑
三、性能
1.首先考虑自己的应用属于 CPU 密集型还是 IO 密集型
2.数据库
3.应用程序
4.中间件(tomact、Nginx)
5.网络和操作系统等方面