文件说明
ab是apache自带的一个很好用的压力测试工具,当安装完apache的时候,就能够在bin下面找到ab
下载连接html
Linux/Mac: 一、yum -y install httpd-tools 查看信息:ab -V 二、http://httpd.apache.org/download.cgi#apache24 Windows:http://www.apachehaus.com/cgi-bin/download.plx 下载后解压,并追加PATH环境变量,如";E:\software\Apache24\bin"
测试用例apache
#咱们能够模拟100个并发用户,对一个页面发送100个请求# ab -n 100 -c 100 -p E:\param.txt -T application/json http://xx.com 经常使用参数 -n 请求数 -c 并发数 -p 参数文本路径 -T 请求参数类型 更多参数 -n 在测试会话中所执行的请求个数。默认时,仅执行一个请求。 -c 一次产生的请求个数。默认是一次一个。 -t 测试所进行的最大秒数。其内部隐含值是-n 50000,它可使对服务器的测试限制在一个固定的总时间之内。默认时,没有时间限制。 -p 包含了须要POST的数据的文件。 -P 对一个中转代理提供BASIC认证信任。用户名和密码由一个:隔开,并以base64编码形式发送。不管服务器是否须要(即, 是否发送了401认证需求代码),此字符串都会被发送。 -T POST数据所使用的Content-type头信息。 -v 设置显示信息的详细程度-4或更大值会显示头信息,3或更大值能够显示响应代码(404,200等),2或更大值能够显示警告和其余信息。 -V 显示版本号并退出。 -w 以HTML表的格式输出结果。默认时,它是白色背景的两列宽度的一张表。 -i 执行HEAD请求,而不是GET。 -x 设置<table>属性的字符串。 -X 对请求使用代理服务器。 -y 设置<tr>属性的字符串。 -z 设置<td>属性的字符串。 -C 对请求附加一个Cookie:行。其典型形式是name=value的一个参数对,此参数能够重复。 -H 对请求附加额外的头信息。此参数的典型形式是一个有效的头信息行,其中包含了以冒号分隔的字段和值的对(如,"Accept-Encoding:zip/zop;8bit")。 -A 对服务器提供BASIC认证信任。用户名和密码由一个:隔开,并以base64编码形式发送。不管服务器是否须要(即,是否发送了401认证需求代码),此字符串都会被发送。 -h 显示使用方法。 -d 不显示"percentage served within XX [ms] table"的消息(为之前的版本提供支持)。 -e 产生一个以逗号分隔的(CSV)文件,其中包含了处理每一个相应百分比的请求所须要(从1%到100%)的相应百分比的(以微妙为单位)时间。因为这种格式已经“二进制化”,因此比'gnuplot'格式更有用。 -g 把全部测试结果写入一个'gnuplot'或者TSV(以Tab分隔的)文件。此文件能够方便地导入到Gnuplot,IDL,Mathematica,Igor甚至Excel中。其中的第一行为标题。 -i 执行HEAD请求,而不是GET。 -k 启用HTTP KeepAlive功能,即在一个HTTP会话中执行多个请求。默认时,不启用KeepAlive功能。 -q 若是处理的请求数大于150,ab每处理大约10%或者100个请求时,会在stderr输出一个进度计数。此-q标记能够抑制这些信息。
返回信息解析json
This is ApacheBench, Version 2.3 <$Revision: 1796539 $> Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/ Licensed to The Apache Software Foundation, http://www.apache.org/ Benchmarking 127.0.0.1 (be patient) Completed 100 requests Completed 200 requests Completed 300 requests Completed 400 requests Completed 500 requests Completed 600 requests Completed 700 requests Completed 800 requests Completed 900 requests Completed 1000 requests Finished 1000 requests Server Software: Apache-Coyote/1.1 ##apache版本 Server Hostname: 127.0.0.1 ##请求的机子 Server Port: 8080 ##请求端口 Document Path: / Document Length: 1825 bytes ##页面长度 Concurrency Level: 100 ##并发数 Time taken for tests: 0.273 seconds ##共使用了多少时间 Complete requests: 1000 ##请求数 Failed requests: 0 ##失败请求 Total transferred: 275000 bytes ##总共传输字节数,包含http的头信息等 HTML transferred: 25000 bytes ##html字节数,实际的页面传递字节数 Requests per second: 3661.60 [#/sec] (mean) ##每秒多少请求,这个是很是重要的参数数值,服务器的吞吐量 Time per request: 27.310 [ms] (mean) ##用户平均请求等待时间 Time per request: 0.273 [ms] (mean, across all concurrent requests) #服务器平均处理时间 Transfer rate: 983.34 [Kbytes/sec] received ##每秒获取的数据长度 Connection Times (ms) min mean[+/-sd] median max Connect: 0 1 2.3 0 16 Processing: 6 25 3.2 25 32 Waiting: 5 24 3.2 25 32 Total: 6 25 4.0 25 48 Percentage of the requests served within a certain time (ms) 50% 25 ## 50%的请求在25ms内返回 66% 26 ## 60%的请求在26ms内返回 75% 26 80% 26 90% 27 95% 31 98% 38 99% 43 100% 48 (longest request)