Apache -- ab 并发测试

安装了 apache 后, 在 bin 目录下会有个叫 ab 的工具。它可以模拟并发的 http 请求。我们可以用它来进行简单的压力测试。

进入 apache 的 bin 目录,运行 ./ab -V 可以查看相关信息:

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 2006 The Apache Software Foundation, http://www.apache.org/

进行某个地址的测试:

[root
@localhost ~]# ab -n1000 -c10 http://statis.abc.cn/

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 2006 The Apache Software Foundation, http://www.apache.org/

Benchmarking statis.abc.cn (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

Finished 1000 requests

Server Software:     nginx/1.0.10

Server Hostname:     statis.abc.cn

Server Port:       80

Document Path:      /

Document Length:     4881 bytes

Concurrency Level:    10

Time taken for tests:  5.341769 seconds

Complete requests:    1000

Failed requests:     0

Write errors:      0

Total transferred:    5253000 bytes

HTML transferred:    4881000 bytes

Requests per second:   187.20 [#/sec] (mean)

Time per request:    53.418 [ms] (mean)

Time per request:    5.342 [ms] (mean, across all concurrent requests)

Transfer rate:      960.17 [Kbytes/sec] received

Connection Times (ms)

min  mean[+/-sd] median  max

Connect:     0  19  11.6   18    40

Processing:   14  33  12.0   33    57

Waiting:    10  29  11.9   29    53

Total:     24  52  9.5   51    91

Percentage of the requests served within a certain time (ms)

50%   51

66%   55

75%   56

80%   59

90%   65

95%   73

98%   78

99%   82

100%   91 (longest request)

--------------------------------------

上面信息的解释:

-n1000

总请求数为 1000

-c10

并发用户数为 10

http://app.abc.cn/

请求目标URL

Server Software

被测试的地址用的WEB服务器名称。这里是 nginx 1.0.10.它来自 HTTP 响应头。

Server Hostname

请求的URL的主机部分名称,也来自 HTTP 响应头。

Server Port

被测试的WEB服务器软件监听端口。

DocumentPath

请求的URL中的根绝对路径,也是来自HTTP请求头。

DocumentLength

响应数据正文长度

Concurrency Level

并发用户数,这里是我们设置的参数。

Time taken for tests

所有这些请求处理完成所用的时间。

Complete requests

总请求数,这里是我们设置的参数

Failed requests

失败的请求数,失败指的是请求在连接服务器,发送数据,接收数据等环境发生异常,以及无响应后超时的情况。对于超时的时间,可以在 ab -t 参数设置.

Total transferred

所有请求的响应数据长度总和。包括每个HTTP响应数据的头信息和正文数据长度。注意,它不包括请求数据的长度。

HTML transferred

表示所有请求的响应数据中正文数据的总和,也就是 Total transferred 中送去响应头的数据总和。

Requests per second

吞吐率: Complete requests / Time

Time per request

用户平均请求等待时间:Time taken for tests / (Complete requests / Concurrency Level)

Time per request

服务器平均请求处理时间:Time taken for tests /Complete requests.这正是吞吐率的倒数

Transfer rate

这些请求在单位时间内从服务器获取的数据长度:Total transferred  / Time taken for tests

这个统计可以很好说明服务器在处理能力达到极限时,其出口带宽的需求量。

Percentage of the requests served within a certain time (ms)

每个请求处理时间的分布情况。上面的结果显示 80% 的请求响应时间不超过 59ms;(这是非常长的时间了,可能页面里有些复杂的逻辑)

*******************************************************

将并发用户数从 10 变成 100,其它条件不变,看结果

[root
@localhost ~]# ab -n1000 -c100 http://statis.abc.cn/

Server Software:     nginx/1.0.10

Server Hostname:     statis.easymobi.cn

Server Port:       80

Document Path:      /

Document Length:     4881 bytes

Concurrency Level:    100

Time taken for tests:  4.746772 seconds

Complete requests:    1000

Failed requests:     0

Write errors:      0

Total transferred:    5265312 bytes

HTML transferred:    4891824 bytes

Requests per second:   210.67 [#/sec] (mean)

Time per request:    474.677 [ms] (mean)

Time per request:    4.747 [ms] (mean, across all concurrent requests)

Transfer rate:      1083.05 [Kbytes/sec] received

Connection Times (ms)

min  mean[+/-sd] median  max

Connect:     1  136 343.4   111   3130

Processing:   22  241 281.6   128   2382

Waiting:    18  181 166.8   125   1176

Total:     41  377 422.1   240   3247

Percentage of the requests served within a certain time (ms)

50%   240

66%   248

75%   255

80%   365

90%   766

95%  1064

98%  1483

99%  3232

100%  3247 (longest request)

从结果中看出,吞吐率从 187.20 增长到 210.67.服务器平均请求处理时间从原来的 5.342ms 降到 4.747ms.而平均等待时间从 53.418 增加到 474.677.

可见,随着并发用户的变化,吞吐率,等待时间,请求处理时间都发生了相应的变化。

时间: 2024-11-06 14:50:14

Apache -- ab 并发测试的相关文章

apache ab压力测试报错apr_socket_recv

apache ab压力测试报错(apr_socket_recv: Connection reset by peer (104)) apache 自带的ab工具测试,当并发量达到1000多的时候报错如下: [[email protected] ~]# ab -n 100000 -c 1000 http://192.168.2.170/index.htmlThis is ApacheBench, Version 2.3 <$Revision: 655654 $>Copyright 1996 Ada

apache ab压力测试报错(apr_socket_recv: Connection reset by peer (104))

apache ab压力测试报错(apr_socket_recv: Connection reset by peer (104)) 今天用apache 自带的ab工具测试,当并发量达到1000多的时候报错如下: [[email protected]~]# This is ApacheBench, Version 2.3 <$Revision: 655654 $> Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech

如何使用、判断Apache AB压力测试

最近公司的一个项目(在线考试软件),客户提出500人在线,设计到登录和最后提交的问题(这两部分是和数据库进行数据的交换).所以在不确定前进行压力测试.在网上了解了一下Apache AB. 软件介绍: 开发语言:jsp   数据库sql2000 web服务 tomcat  服务器环境:win2003 .win2008(备选) 关于apache AB 测试: Apache附带的ab工具(本机使用的PHP环境是WAMP集成环境,ab工具位于apache\bin下)非常容易使用,ab可以直接在Web服务

Apache ab并发负载压力测试

由于现在网站都需要能够承受高并发要求的能力,所以当我们写完代码后,如果需要上线,最好都经过压力测试后,这样比较好 运行: 在Windows系统下,打开cmd命令行窗口,定位到apache安装目录的bin目录下 cd C:\Program Files (x86)\Apache Software Foundation\Apache2.2\bin 键入命令: ab -n 800 -c 800  http://192.168.0.10/ (-n发出800个请求,-c模拟800并发,相当800人同时访问,

Apache ab 压力测试工具

Apache Bin目录下的 ab.exe(ApacheBench) 程序是专门用在做压力测试用的软件. ApacheBench(ab) 用来测试 apache 执行效率,专门用来执行网站服务器的运行效能,特别是针对Apache 网站服务器,这原本是用来检测 Apache 网站服务器能够提供的效能,特别是可以看出Apache能提供每秒能送出多少网页. ab 使用的示例: Usage: /usr/sbin/ab [options] [http[s]://]hostname[:port]/path

apache ab压力测试

今天提到压力测试,想起以前看到的ab,于是又重新查找了下资料,并记录了下. ab命令会创建很多的并发访问线程,模拟多个访问者同时对某一URL地址进行访问. 它的测试目标是基于URL的,因此,既可以用来测试Apache的负载压力,也可以测试nginx.lighthttp.tomcat.IIS等其它Web服务器的压力. ab命令对发出负载的计算机要求很低,既不会占用很高CPU,也不会占用很多内存,但却会给目标服务器造成巨大的负载,其原理类似CC攻击.自己测试使用也须注意,否则一次上太多的负载,可能造

apache AB压力测试工具参数说明

参数 -n requests     Number of requests to perform //在测试会话中所执行的请求个数.默认时,仅执行一个请求 -c concurrency Number of multiple requests to make //一次产生的请求个数.默认是一次一个. -t timelimit    Seconds to max. wait for responses //测试所进行的最大秒数.其内部隐含值是-n 50000.它可以使对服务器的测试限制在一个固定的总

【Apache】Apache ab压力测试工具Window下载和用法详解

ab是apache自带的网站压力测试工具. 使用起来非常的简单和方便. 不仅仅是可以apache服务器进行网站访问压力测试,还可以对其他类型的服务器进行压力测试. 比如nginx,tomcat,IIS等 首先当然是下载安装了. 在这里只讲window下在下载安装 官方下载地址:,(https://www.apachehaus.com/cgi-bin/download.plx) 下载完成后解压 修改解压根目录下的conf/httpd.conf文件的端口配置,默认是80端口,应该是被占用了,无法安装

apache 多并发测试

进入到apache的bin目录打开  temp.bat 如果没有,新建temp.bat,打开输入 命令:ab -c 一次并发的数量 -n 总共请求的数量 请求的地址 例:ab -c 10 -n 100 test.com