apache 的ab 工具

ab是apache 进行http服务器压力测试的一个工具。用来衡量apache 服务器的执行效率,能够检测出apache每秒能够处理的请求数。

一个使用的例子如下(windows下)

ab -n  -c  http://www.baidu.com/

上面这个命令能够检测百度服务器的承压情况,其中-n 100表示总共发起100个连接请求,而-c 10表示同时维持10个并发。测试结果如下和字段的含义解释如下(飘黄是解释):

This is ApacheBench, Version 2.3 <$Revision: 1554214 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/ Benchmarking www.baidu.com (be patient).....done
Server Software:        BWS/1.1      ##  服务器的软件名称, 如果是apache,则会显示是apache,这个字段选自http的response头部的header 字段
Server Hostname: www.baidu.com ## 请求的域名
Server Port: 80      ## 请求的端口 Document Path: /        ## 本次请求的文档路径
Document Length: 86001 bytes  ## 请求的response的文档大小 Concurrency Level: 10     ## 并发度,对应了命令中的 -c 10
Time taken for tests: 6.901 seconds  ## 测试花费的时间
Complete requests: 100        ## 完成的请求个数
Failed requests: 95        ## 失败的请求个数
(Connect: 0, Receive: 0, Length: 95, Exceptions: 0)
Total transferred: 8696312 bytes  ## 从服务器接收的byte个数,包含http头
HTML transferred: 8610757 bytes  ## 从服务器接收的html文档的总个数
Requests per second: 14.49 [#/sec] (mean) ##每秒处理的请求书14.49 = 100 / 6.901
Time per request: 690.140 [ms] (mean) ##单一请求的处理时间(客户端感知的时间)
Time per request: 69.014 [ms] (mean, across all concurrent requests) ##每个请求的处理时间(加上并发), 侧重于看服务器端的处理能力
Transfer rate: 1230.55 [Kbytes/sec] received ##传输速率 Connection Times (ms)
              min  mean[+/-sd] median   max
Connect: 1 64 421.1 4 3000
Processing: 11 615 1164.2 62 3146
Waiting: 3 253 765.6 27 3062
Total: 12 679 1214.4 63 3151 ##最快的请求响应时间是12ms, 最长的是3151ms Percentage of the requests served within a certain time (ms) ## 给定时间内得到响应的请求数(百分比)
50% 63   ## 63ms内50%的请求得到了响应
66% 142
75% 164
80% 3033
90% 3107
95% 3133
98% 3141
99% 3151
100% 3151 (longest request)

ab工具虽然是apache用来给自己做测试用,也可以用来测试其他版本的服务器。功能上ab比较完整,支持多个参数,捡几个常用的介绍一下。

-k 启用 KeepAlive, 一个会话里发起多个请求。
-i 发起HEAD请求,而不是GET请求

其他的参数用到的时候在解释吧。

我在测试自己写的简单服务器时会发现出一个错误:

Benchmarking 127.0.0.1 (be patient)...apr_socket_recv: 远程主机强迫关闭了一个现有的连接。 (730054)

查了一下资料, 需要加上-k的参数来解决。

上一篇:centos 7.0 安装nginx 1.117


下一篇:Ubuntu上安装Karma失败对策