linux下使用ab进行压力测试


ab的全称是ApacheBench,是Apache 附带的一个小工具,专门用于 HTTP Server 的benchmark testing,可以同时模拟多个并发请求。
最基本的关心两个选项 -c -n
1.(get方式)ab -n 1000 -c 1000 -k http://xxx.xxxxx.com/synth/open/recurls.do?test=true
2.(post方式) ab -n 2500 -c 2500 -k -p postfile.ab http://xxx.xxxx.com/synth/open/getTheme.do (postfile.ab中为json数据)
-c 100 即:每次并发100个
-n 10000 即: 共发送10000个请求
-k 为keep_alive,可省略,一般出现链接被重置的错误时最好带上-k的参数。(测试长连接使用,apache的话需要配置KeepAlive On)
结果的一些说明:
/*整个测试持续的时间*/
Time taken for tests:   3.234651 seconds
/*完成的请求数量*/
Complete requests:      10
/*失败的请求数量*/
Failed requests:        0
Write errors:           0
Non-2xx responses:      10
Keep-Alive requests:    10
/*整个场景中的网络传输量*/
Total transferred:      6020 bytes
/*整个场景中的HTML内容传输量*/
HTML transferred:       2300 bytes
/*每秒请求数(平均), 大家最关心的指标之一,相当于 LR 中的 每秒事务数 ,后面括号中的 mean 表示这是一个平均值*/
Requests per second:    3.09 [#/sec] (mean)
/*每次并发请求时间(所有并发), 大家最关心的指标之二,相当于 LR 中的 平均事务响应时间 ,后面括号中的 mean 表示这是一个平均值*/
Time per request:       3234.651 [ms] (mean)              //比如共请求50次,并发数为10,则共需要5次10并发,这个数据就是每次10个并发的共花费时间相加后除以5.
/*每一请求时间(并发平均)  //每个请求实际运行时间的平均值*/
Time per request:       323.465 [ms] (mean, across all concurrent requests)
/*平均每秒网络上的流量,可以帮助排除是否存在网络流量过大导致响应时间延长的问题*/
Transfer rate:          1.55 [Kbytes/sec] received
/*传输速率连接时间,网络上消耗的时间的分解,可以帮助排除是否存在网络流量过大导致响应时间延长的问题*/
Connection Times (ms)
min  mean[+/-sd] median   max
Connect:       20  318 926.1     30    2954
Processing:    40 2160 1462.0   3034    3154
Waiting:       40 2160 1462.0   3034    3154
Total:         60 2479 1276.4   3064    3184
/*下面的内容为整个场景中所有请求的响应情况。在场景中每个请求都有一个响应时间,其中 50% 的用户响应时间小于 3064 毫秒,60 % 的用户响应时间小于 3094 毫秒,最大的响应时间小于 3184 毫秒*/
Percentage of the requests served within a certain time (ms)
50%   3064
66%   3094
75%   3124
80%   3154
90%   3184
95%   3184
98%   3184
99%   3184
100%   3184 (longest request)