ab 的全称是ApacheBench,是 Apache 附带的一个小工具,专门用于 HTTP Server 的benchmark testing,能够同时模拟多个并发请求。前段时间看到公司的开发人员也在用它做一些测试,看起来也不错,很简单,也很容易使用,因此今天花一点时间看 了一下。html
经过下面的一个简单的例子和注释,相信你们能够更容易理解这个工具的使用。 一个简单的例子 /* 在这个例子的一开始,我执行了这样一个命令 ab -n 10 -c 10 http://www.google.com/(不要忘了最后一个'/')。这个命令的意思是启动 ab ,向 www.google.com 发送10个请求(-n 10) ,并每次发送10个请求(-c 10)——也就是说一次都发过去了。跟着下面的是 ab 输出的测试报告。*/ C:\wamp\bin\apache\Apache2.2.11\bin>ab -n 10 -c 10 http://www.google.com This is ApacheBench, Version 2.0.40-dev <$Revision: 1.146 $> apache-2.0 Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/ Copyright 1997-2005 The Apache Software Foundation, http://www.apache.org/ Benchmarking www.google.com (be patient).....done Server Software: GWS/2.1 Server Hostname: www.google.com Server Port: 80 Document Path: / Document Length: 230 bytes Concurrency Level: 10 /*整个测试持续的时间*/ 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) /*这个还不知道是什么意思,有知道的朋友请留言,谢谢 ^_^ */ 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) 更 多信息 ab 不像 LR 那么强大,可是它足够轻便,若是只是在开发过程当中想检查一下某个模块的响应状况,或者作一些场景比较简单的测试,ab 仍是一个不错的选择——至少不用花费不少时间去学习 LR 那些复杂的功能,就更别说那 License 的价格了。 ab是Apache 超文本传输协议(HTTP)的性能测试工具。 其设计意图是描绘当前所安装的Apache的执行性能, 主要是显示你安装的Apache每秒能够处理多少个请求。 选项 -A auth-username:password 对 服务器提供BASIC认证信任。 用户名和密码由一个:隔开,并以base64编码形式发送。 不管服务器是否须要(即, 是否发送了401认证需求代码),此字符串都会被发送。 -c concurrency 一次产生的请求个数。默认是一次一个。 -C cookie-name=value 对请求附加一个Cookie:行。 其典型形式是name=value的一个参数对。 此参数能够重复。 -d 不 显示"percentage served within XX [ms] table"的消息(为之前的版本提供支持)。 -e csv-file 产生一个以逗号分隔的(CSV)文件, 其中包含了处理每一个相应百分比的请求所须要(从1%到100%)的相应百分比的(以微妙为单位)时间。 因为这种格式已经“二进制化”,因此比'gnuplot'格式更有用。 -g gnuplot-file 把全部测试结果写入一个 'gnuplot'或者TSV (以Tab分隔的)文件。 此文件能够方便地导入到Gnuplot, IDL, Mathematica, Igor甚至Excel中。 其中的第一行为标题。 -h 显示使用方法。 -H custom-header 对请求附加额外 的头信息。 此参数的典型形式是一个有效的头信息行,其中包含了以冒号分隔的字段和值的对 (如, "Accept-Encoding: zip/zop;8bit"). -i 执行HEAD请求,而不是GET。 -k 启用HTTP KeepAlive功能,即, 在一个HTTP会话中执行多个请求。 默认时,不启用KeepAlive功能. -n requests 在测试会话中所执行的请求个数。 默认时,仅执行一个请求,但一般其结果不具备表明意义。 -p POST-file 包含了须要POST的数据的文件. -P proxy-auth-username:password 对一个中转代理提供BASIC认证信任。 用户名和密码由一个:隔开,并以base64编码形式发送。 不管服务器是否须要(即, 是否发送了401认证需求代码),此字符串都会被发送。 -q 如 果处理的请求数大于150, ab每处理大约10%或者100个请求时,会在stderr输出一个进度计数。 此-q标记能够抑制这些信息。 -s 用 于编译中(ab -h会显示相关信息)使用了SSL的受保护的https, 而不是http协议的时候。此功能是实验性的,也是很简陋的。最好不要用。 -S 不 显示中值和标准背离值, 并且在均值和中值为标准背离值的1到2倍时,也不显示警告或出错信息。 默认时,会显示 最小值/均值/最大值等数值。(为之前的版本提供支持). -t timelimit 测试所进行的最大秒数。其内部隐含值是-n 50000。 它可使对服务器的测试限制在一个固定的总时间之内。默认时,没有时间限制。 -T content-type POST数据 所使用的Content-type头信息。 -v verbosity 设置显示信息的详细程度 - 4或更大值会显示头信息, 3或更大值能够显示响应代码(404, 200等), 2或更大值能够显示警告和其余信息。 -V 显示版本号并退出。 -w 以 HTML表的格式输出结果。默认时,它是白色背景的两列宽度的一张表。 -x <table>-attributes 设 置<table>属性的字符串。 此属性被填入<table 这里 >. -X proxy[:port] 对请求 使用代理服务器。 -y <tr>-attributes 设置<tr>属性的字符串. -z <td>-attributes 设置<td>属性的字符串. 缺陷 程序中有各类静态声明的固定长 度的缓冲区。 另外,对命令行参数、服务器的响应头和其余外部输入的解析也很简单,这可能会有不良后果。 它没有完整地实现 HTTP/1.x; 仅接受某些'预想'的响应格式。 strstr(3)的频繁使用可能会带来性能问题,即, 你多是在测试ab而不是服务器的性能。 相 关连接 ab 是 Apache 的一个安装组件,因此须要下载 Apache 安装后才能使用,能够访问 Apache 的项目主页来下载 http://httpd.apache.org/download.cgi ab 的更多信息能够参加 Apache 主页上的描述 http://httpd.apache.org/docs/2.0/programs/ab.html 如下是ab的使用帮助: Usage: ab [options] [http://]hostname[:port]/path Options are: -n requests Number of requests to perform -c concurrency Number of multiple requests to make -t timelimit Seconds to max. wait for responses -b windowsize Size of TCP send/receive buffer, in bytes -p postfile File containing data to POST. Remember also to set -T -T content-type Content-type header for POSTing, eg. 'application/x-www-form-urlencoded' Default is 'text/plain' -v verbosity How much troubleshooting info to print -w Print out results in HTML tables -i Use HEAD instead of GET -x attributes String to insert as table attributes -y attributes String to insert as tr attributes -z attributes String to insert as td or th attributes -C attribute Add cookie, eg. 'Apache=1234. (repeatable) -H attribute Add Arbitrary header line, eg. 'Accept-Encoding: gzip' Inserted after all normal header lines. (repeatable) -A attribute Add Basic WWW Authentication, the attributes are a colon separated username and password. -P attribute Add Basic Proxy Authentication, the attributes are a colon separated username and password. -X proxy:port Proxyserver and port number to use -V Print version number and exit -k Use HTTP KeepAlive feature -d Do not show percentiles served table. -S Do not show confidence estimators and warnings. -g filename Output collected data to gnuplot format file. -e filename Output CSV file with percentages served -r Don't exit on socket receive errors. -h Display usage information (this message)