服务器压力测试是什么?
首先要了解服务器的吞吐量,这是指单位时间内服务器的处理请求数,通常使用“reqs/s”(服务器每秒处理请求的数量)表示。在一些常见的web服务器软件中,通常提供当前服务器运行状态以及吞吐量的查看方法。
吞吐量只描述服务器实际运行期间单位时间内的处理请求数,而我们更关心服务器并发处理能力的上限,即单位时间内服务器能处理的最大请求数(即最大吞吐率)。但是测试时,很难调动足够的人测试服务器的最大吞吐率。所以,需要使用某些方法及工具来模拟足够的数目的并发用户数,这种方法称为:“服务器压力测试”。
服务器压力测试目的是在项目投入使用以前或负载达到极限以前,通过执行可重复的负载测试,了解服务器系统可靠性、性能瓶颈等,以提高服务器系统的可靠性、稳定性,减少系统的宕机时间和因此带来的损失?
服务器压力测试的类型
1.峰值测试:主要是考验一个服务器承载上限
2.同屏压测:即同一屏幕同时承载测试
3.行为压测:即根据用户行为消耗资源测试
4.数据压测:即数据上限测试
5.设备压测:不同的设备支持不同的运行环境
服务器压力测试工具
1、JMeter:
JMeter是Apache组织开发的基于Java的压力测试工具。它可以用于测试静态和动态资源,可以用于对服务器、网络或对象模拟巨大的负载,来自不同压力类别下测试它们的强度和分析整体性能。
另外,JMeter能够对应用程序做功能/回归测试,通过创建带有断言的脚本来验证你的程序返回了你期望的结果。为了最大限度的灵活性,JMeter允许使用正则表达式创建断言。
2、阿里云PTS:
进入阿里云性能测试官网首页,单击立即开通,进入开通流程。
阿里云的性能测试PTS无需安装软件;脚本场景监控简单化,省时、省力;分布式并发压测,施压能力无上限;快速大规模集群扩容、支持几十万用户及百万级TPS性能压测;可模拟海量用户的真实业务场景,全方位验证业务站点的性能、容量和稳定性。
性能测试 PTS(Performance Testing Service)是具备强大的分布式压测能力的 SaaS 压测平台,可模拟海量用户的真实业务场景,全方位验证业务站点的性能、容量和稳定性。
PTS 目标是将性能压测本身的工作持续简化,使您可以将更多的精力回归到关注业务和性能问题本身。在 PTS 平台上,您可以用最低的人力和资源成本,构造出最接近真实业务场景的复杂交互式流量,快速衡量系统的业务性能状况,为性能问题定位、容量最佳配比、全链路压测的流量构造提供最好的帮助。进而提升用户体验,促进业务发展,最大程度实现企业的商业价值。
PTS 广泛应用于各种压力测试和性能测试场景,包括但不限于以下场景:
压测流程
PTS 提供全面高效的压测流程:
压测创建方式
PTS 支持以下 4 种方式创建压测场景(或称压测用例),如图所示:
说明:
- 方式一: PTS 自研零编码可视化编排,使用自研强大引擎压测。
- 方式二: 使用 PTS 自研云端录制器,零侵入录制业务请求并导入 1 中的自研交互中进行进一步设置。
- 方式三: 将已有的JMeter脚本导入 1 中的 PTS 自研交互中,使用 PTS 自研引擎。
-
方式四: 导入 JMeter 脚本并使用原生 JMeter 引擎进行压测,PTS 提供自定义的压力构造和监控数据汇聚等产品服务。
其中,方式一、二、三由于使用了 PTS 的自研引擎,具备 RPS(Requests per Second)吞吐量压测模式、秒级启动、实时控制、定时压测和流量遍布全国运营商网络的差异化能力。
方式一是 PTS 最核心的一种压测场景创建方式,所有资源包均可使用。其他几种创建方式面向不同规格资源包开放,详见产品价格说明,并购买相应资源包。
具体可见《如何在1分钟之内发起压力测试》
3、http_load:
http_load以并行复用的方式运行,用以测试web服务器的吞吐量与负载。
但是它不同于大多数压力测试工具,它可以以一个单一的进程运行,一般不会把客户机搞死。
还可以测试HTTPS类的网站请求。
下载地址:http_load-12mar2006.tar.gz
安装很简单
#tar zxvf http_load-12mar2006.tar.gz #cd http_load-12mar2006 #make && make install
基本用法:
http_load -p 并发访问进程数 -s 访问时间 需要访问的URL文件
参数其实可以自由组合,参数之间的选择并没有什么限制。
比如你写成http_load -parallel 5 -seconds 300 urllist.txt也是可以的。
我们把参数给大家简单说明一下。
-parallel 简写-p :含义是并发的用户进程数。
-fetches 简写-f :含义是总计的访问次数
-rate 简写-p :含义是每秒的访问频率
-seconds 简写-s :含义是总计的访问时间
准备URL文件:urllist.txt,文件格式是每行一个URL,URL最好超过50-100个测试效果比较好。
文件格式如下:
http://t.cn/EohSQWn http://t.cn/EhANgYe http://t.cn/EohSQWE http://t.cn/EohSQWm http://t.cn/EohSQlA http://t.cn/EohSQW3 http://t.cn/EohSQWu
例如:
http_load -p 30 -s 60 urllist.txt
参数了解了,我们来看运行一条命令来看看它的返回结果如下:
结果分析:
- 294 fetches, 30 max parallel, 3.83835e+06 bytes, in 60.0026 seconds
说明在上面的测试中运行了294个请求,最大的并发进程数是30,总计传输的数据是3.83835e+06bytes,运行的时间是60.0026秒 - 13055.6 mean bytes/connection
说明每一连接平均传输的数据量3.83835e+06/294=13055.6 - 4.89979 fetches/sec, 63969.7 bytes/sec
说明每秒的响应请求为4.89979,每秒传递的数据为63969.7 bytes/sec - msecs/connect: 312.009 mean, 1319.57 max, 209.994 min
说明每连接的平均响应时间是312.009 msecs,最大的响应时间1319.57 msecs,最小的响应时间209.994 msecs - msecs/first-response: 1191.01 mean, 10212.4 max, 220.78 min
- HTTP response codes:
- 200 – 127
code 502 – 166
说明打开响应页面的类型。
如果403的类型过多,那可能要注意是否系统遇到了瓶颈。
特殊说明:
测试结果中主要的指标是 fetches/sec、msecs/connect 这个选项,即服务器每秒能够响应的查询次数。
用这个指标来衡量性能。似乎比 apache的ab准确率要高一些,也更有说服力一些。
Qpt-每秒响应用户数和response time,每连接响应用户时间。
测试的结果主要也是看这两个值。
当然仅有这两个指标并不能完成对性能的分析,我们还需要对服务器的cpu、men进行分析,才能得出结论。
2、webbench
webbench是Linux下的一个网站压力测试工具,最多可以模拟3万个并发连接去测试网站的负载能力。
下载地址可以到google搜,我这里给出一个
下载地址:webbench-1.5.tar.gz
这个程序更小,解压后不到50K,呵呵
安装非常简单
#tar zxvf webbench-1.5.tar.gz #cd webbench-1.5 #make && make install
会在当前目录生成webbench可执行文件,直接可以使用了
用法:webbench -c 并发数 -t 运行测试时间 URL
例如:
#webbench -c 1000 -t 130 http://t.cn/EohSQWn
3、apache bench(主要是用来测试apache的)
ab是apache自带的一款功能强大的测试工具。
安装了apache一般就自带了。
用法可以查看它的说明
#./ab
参数众多,一般我们用到的是-n 和-c
例如:
#webbench -c 1000 -t 130 http://t.cn/EohSQWn
这个表示同时处理1000个请求并运行130次http://t.cn/EohSQWn路径。
4、Siege
一款开源的压力测试工具,可以根据配置对一个WEB站点进行多用户的并发访问,记录每个用户所有请求过程的相应时间,并在一定数量的并发访问下重复进行。
Siege官方:http://www.joedog.org/
Siege下载:siege-latest.tar.gz
Siege解压并安装:
# tar -zxvf siege-latest.tar.gz # cd siege-latest/ #./configure #make #make install
Siege使用:
#siege -c 100 -r 10 -f site.url
-c是并发量,-r是重复次数。
url文件就是一个文本,每行都是一个url,它会从里面随机访问的。
site.url内容:
http://t.cn/EohSQWn http://t.cn/EhANgYe http://t.cn/EohSQWE http://t.cn/EohSQWm http://t.cn/EohSQlA http://t.cn/EohSQW3 http://t.cn/EohSQWu
结果说明:
Transactions: 550 hits //完成550次处理 Availability: 55.00 % //55.00 % 成功率 Elapsed time: 31.32 secs //总共用时 Data transferred: 1.15 MB //共数据传输1.15 MB Response time: 3.04 secs //显示网络连接的速度 Transaction rate: 17.56 trans/sec //均每秒完成 17.56 次处理:表示服务器后 Throughput: 0.04 MB/sec //平均每秒传送数据 Concurrency: 53.44 //实际最高并发数 Successful transactions: 433 //成功处理次数 Failed transactions: 450 //失败处理次数 Longest transaction: 15.50 //每次传输所花最长时间 Shortest transaction: 0.42 //每次传输所花最短时间
总结:
下面几款免费的服务器压力测试软件的限制多一些,而且运维人员进行还要费时费力的配置。对于有大流量的企业来讲,时间要重要的多,钱已经不是事儿了,所以能用钱解决的问题尽量别耽误时间。这里的几种工具,大家可以自己选择使用。