怎么做服务器压力测试?
项目做好了,能不能顺利上线?
一般来说我们需要做一下压力测试来判断。比如该项目上线后预计每天一百万的接口访问量,并且访问时段主要集中在早八点到晚八点,那么平均下来 RPS 大约是 22 次左右,不过用户的访问量通常不会很平均,假设峰值流量是平均流量的 3 到 5 倍的话,那么我们可以推断出项目要想顺利上线,RPS 至少应该达到 66+ 次,110+ 次更好。
由此可见上线前用压力测试工具测试 RPS 是一个很重要的环节。
下面小编给大家介绍几款Web服务器性能压力测试工具。
一、先说花钱的
没有钱解决不了的事,如果有,那一定是钱不够。
阿里云推出了一款测压服务:阿里云性能测试PTS
阿里云的性能测试PTS无需安装软件;脚本场景监控简单化,省时、省力;分布式并发压测,施压能力无上限;快速大规模集群扩容、支持几十万用户及百万级TPS性能压测;可模拟海量用户的真实业务场景,全方位验证业务站点的性能、容量和稳定性。
PTS 广泛应用于各种压力测试和性能测试场景,包括但不限于以下场景:
详细参考《如何在一分钟内发起压测?》
二、再说不花钱的
1、http_load
程序非常小,解压后也不到100K
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个测试效果比较好。
文件格式如下:
https://iil.ink/m6c5a
https://iil.ink/qiyeji2zhe
https://iil.ink/rds85zhe
https://iil.ink/txljsl
https://iil.ink/gamedun
https://iil.ink/duanxinsms
https://iil.ink/alicdn
例如:
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 https://iil.ink/m6c5a
3、apache bench(主要是用来测试apache的)
ab是apache自带的一款功能强大的测试工具。
安装了apache一般就自带了。
用法可以查看它的说明
#./ab
参数众多,一般我们用到的是-n 和-c
例如:
#webbench -c 1000 -t 130 https://iil.ink/m6c5a
这个表示同时处理1000个请求并运行130次https://iil.ink/m6c5a
路径。
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内容:
https://iil.ink/m6c5a
https://iil.ink/qiyeji2zhe
https://iil.ink/rds85zhe
https://iil.ink/txljsl
https://iil.ink/gamedun
结果说明:
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 //每次传输所花最短时间
总结:
相对于花钱的,不花钱的限制肯定多一些,而且还要费时费力的配置。对于有大流量企业来讲,钱已经不是事儿了,所以能用钱解决的问题尽量别耽误时间。这里只讲一下几种工具,方便大家测试。
原文:怎么做服务器压力测试?
怎么做服务器压力测试?相关推荐
- 怎么做服务器压力测试? 1
项目做好了,能不能顺利上线? 一般来说我们需要做一下压力测试来判断.比如该项目上线后预计每天一百万的接口访问量,并且访问时段主要集中在早八点到晚八点,那么平均下来 RPS 大约是 22 次左右,不过用 ...
- 利用apache的ab命令做服务器压力测试
在window系统下,先定位到apache安装目录的bin文件夹. 使用 ab -n1000 -c10 http://localhost:80/ 命令. 其中,n参数表示请求数,c参数表示并发数. ( ...
- 游戏上线前服务器压力测试应该怎么做
伴随手游上线推广,玩家爆发式增长非常常见,不少开发者都遇到过玩家冲爆服务器的情况.因此降低服务器崩溃的风险就显得非常重要.游戏上线前如果做了服务器压力测试帮助会很大.今天就来说说压力测试. 编写脚本机 ...
- 服务器压力测试 性能测试 AB、Webbench、Tsung
负载生成器是一些生成用于测试的流量的程序.它们可以向你展示服务器在高负载的情况下的性能,以及让你能够找出服务器可能存在的问题.为了得到更加客观和准确的数值,应该从远程访问.局域网访问和 ...
- 服务器测压网站,网站服务器压力测试
网站服务器压力测试 内容精选 换一换 简要介绍Web Bench是Linux中被广泛使用的网站压力测试工具,同时支持HTTPS静态网站和动态网站.编写语言:C/C++一句话概述:网站压力测试工具建议的 ...
- 邮件服务器压力测试工具postal
邮件服务器压力测试工具Postal postal下载 http://doc.coker.com.au/projects/postal/ postal安装 [root@Mailbox ~]#tar zx ...
- 服务器压力测试_魔兽世界怀旧服:美服18日开放安其拉开门测试,P5阶段即将来临...
了解魔兽最新资讯,关注小乖闪闪.大家好,我是小乖.<魔兽世界>怀旧服P5阶段已经在外服开放测试.就在近日,美服又一次发布蓝贴,其内容主要是<魔兽世界>怀旧服PTR将于18日星( ...
- 服务器压力测试_性能测试相关的面试题
1.请问什么是性能测试.负载测试.压力测试? 性能测试:对一个软件系统而言,包括执行效率.资源占用.系统稳定性.安全性兼容性.可扩展性等. 负载测试:指在超负荷环境中运行,确定系统的处理能力,以及系统 ...
- jmetter持续时间_【转】Jmeter做web压力测试时设置持续时间注意点
头一回使用jmeter做web的压力测试,遇到个很莫名其妙的问题,不管我的线程组怎么设置,它就是执行一次就结束了. 设置循环次数为300,不使用调度器--〉执行一次就结束了,循环次数未生效 设置循环次 ...
最新文章
- 互联网高薪的原因、现状、未来,还值不值得进来?
- Element 对象表示 XML 文档中的元素。
- 用 Python 拓展 GDB(三)
- python dataframe是什么_python – 逐个构建DataFrame的最快方法是什么?
- Android 目录
- 高数复习9.13 函数与极限
- 数的划分(信息学奥赛一本通-T1440)
- 项目发布Debug和Release版的区别
- 使用dig或nslookup指定dns服务器查询域名解析
- 去年的今天我们举行了婚礼
- 利用QT实现中国象棋
- 【自然语言处理】【文本风格迁移】基于风格实例的文本风格迁移
- 【Python算法】:n个点m条边有权无向图
- HNUST OJ 2293 贪吃蛇吃苹果
- python turtle隐藏画笔_Python turtle库的画笔控制说明
- stm32 usart的BRR寄存器的配置,程序是CMSIS中的,分析它是怎么实现的?(自己设置好波特率,库文件会根据波特率计算BRR的值,和以前STM8不一样,需要自己根据波特率计算BRR值再设置)
- 头一回见!提升10倍效率,阿里给业务校验平台插上了AI的翅膀
- 高通平台Android源码bootloader分析之sbl1(一)
- 讼卦,帮助你处理好和上级的关系
- 聪明是一种天赋,而善良是一种选择