怎么做服务器压力测试
的有关信息介绍如下:一般来说我们需要做一下压力测试来判断。比如该项目上线后预计每天一百万的接口访问量,并且访问时段主要集中在早八点到晚八点,那么平均下来 RPS 大约是 22 次左右,不过用户的访问量通常不会很平均,假设峰值流量是平均流量的 3 到 5 倍的话,那么我们可以推断出项目要想顺利上线,RPS 至少应该达到 66+ 次,110+ 次更好。
由此可见上线前用压力测试工具测试 RPS 是一个很重要的环节。
1.直接介绍工具:http_load
程序非常小,解压后也不到100Khttp_load以并行复用的方式运行,用以测试web服务器的吞吐量与负载。但是它不同于大多数压力测试工具,它可以以一个单一的进程运行,一般不会把客户机搞死。还可以测试HTTPS类的网站请求。
2.安装命令如下:
#tar zxvf http_load-12mar2006.tar.gz
#cd http_load-12mar2006
#make && make install
3.基本用法:
http_load -p 并发访问进程数 -s 访问时间 需要访问的URL文件
参数其实可以自由组合,参数之间的选择并没有什么限制。
比如你写成http_load -parallel 5 -seconds 300 urllist.txt也是可以的。
我们把参数给大家简单说明一下。
-parallel 简写-p :含义是并发的用户进程数。-fetches 简写-f :含义是总计的访问次数
-rate 简写-p :含义是每秒的访问频率-seconds 简写-s :含义是总计的访问时间
实际测试语句:http_load -p 30 -s 60 urllist.txt
4.结果分析:
294 fetches 说明在上面的测试中运行了294个请求,
30 max parallel,最大的并发进程数是30,
3.83835e+06 bytes 总计传输的数据是3.83835e+06bytes,
in 60.0026 seconds,运行的时间是60.0026秒
13055.6 mean bytes/connectio
说明每一连接平均传输的数据量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
5.特殊说明:测试结果中主要的指标是 fetches/sec、msecs/connect 这个选项,即服务器每秒能够响应的查询次数。用这个指标来衡量性能。似乎比 apache的ab准确率要高一些,也更有说服力一些。Qpt-每秒响应用户数和response time,每连接响应用户时间。测试的结果主要也是看这两个值。当然仅有这两个指标并不能完成对性能的分析,我们还需要对服务器的cpu、men进行分析,才能得出结论。