ab的事理:ab命令会创建多个并发访问线程,仿照多个访问者同时对某一URL地址进行访问。
它的测试目标是基于URL的,因此,它既可以用来测试apache的负载压力,也可以测试nginx、lighthttp、tomcat、IIS等其它Web做事器的压力。

ab命令对发出负载的打算机哀求很低,它既不会占用很高CPU,也不会占用很多内存。
但却会给目标做事器造成巨大的负载,其事理类似CC攻击。
自己测试利用也须要把稳,否则一次上太多的负载。
可能造成目标做事器资源耗完,严重时乃至导致去世机。

先打开Apache做事器的安装路径,在bin目录中有一个ab.exe的可实行程序,便是我们要先容的压力测试工具。

php压力测试工具Apache自带的ab压力测试对象用法详解 PHP

在Windows系统的命令行下,进入ab.exe程序所在目录,实行ab.exe程序。
把稳直接双击无法精确运行。

实行ab命令成功后,可以看到如图提示。
该帮助很清楚详细的先容了ab的用法以及各个参数的含义。

ab 的用法是:ab [options] [http://]hostname[:port]/path

例如:ab -n 5000 -c 200 http://localhost/index.php

上例表示统共访问http://localhost/index.php这个脚本5000次,200并发同时实行。

ab常用参数的先容:

-n :统共的要求实行数,缺省是1;

-c: 并发数,缺省是1;

-t:测试所进行的总韶光,秒为单位,缺省50000s

-p:POST时的数据文件

-w: 以HTML表的格式输出结果

实行测试用例:ab -n 1000 -c 100 -w http://localhost/index.php >>d:\miss.html

上面的测试用例表示100并发的情形下,共测试访问index.php脚本1000次,并将测试结果保存到d:\miss.html文件中。

结果

把稳:

如果不想安装apache但是又想利用ab命令的话,我们可以直接安装apache的工具包httpd-tools。
如下:

yum -y install httpd-tools

查看ab是否安装成功,可以切换到上述目录下,利用ab –V命令进行检测。
如下:

ab -V

ab性能指标

在进行性能测试过程中有几个指标比较主要:

1、吞吐率(Requests per second)

做事器并发处理能力的量化描述,单位是reqs/s,指的是在某个并发用户数下单位韶光内处理的要求数。
某个并发用户数下单位韶光内能处理的最大要求数,称之为最大吞吐率。

记住:吞吐率是基于并发用户数的。
这句话代表了两个含义:

a、吞吐率和并发用户数干系

b、不同的并发用户数下,吞吐率一样平常是不同的

打算公式:总要求数/处理完成这些要求数所花费的韶光,即

Request per second=Complete requests/Time taken for tests

必须要解释的是,这个数值表示当前机器的整体性能,值越大越好。

2、并发连接数(The number of concurrent connections)

并发连接数指的是某个时候做事器所接管的要求数目,大略的讲,便是一个会话。

3、并发用户数(Concurrency Level)

要把稳区分这个观点和并发连接数之间的差异,一个用户可能同时会产生多个会话,也即连接数。
在HTTP/1.1下,IE7支持两个并发连接,IE8支持6个并发连接,FireFox3支持4个并发连接,以是相应的,我们的并发用户数就得除以这个基数。

4、用户均匀要求等待韶光(Time per request)

打算公式:处理完成所有要求数所花费的韶光/(总要求数/并发用户数),即:

Time per request=Time taken for tests/(Complete requests/Concurrency Level)

5、做事器均匀要求等待韶光(Time per request:across all concurrent requests)

打算公式:处理完成所有要求数所花费的韶光/总要求数,即:

Time taken for/testsComplete requests

可以看到,它是吞吐率的倒数。

同时,它也即是用户均匀要求等待韶光/并发用户数,即

Time per request/Concurrency Level

ab还可以测试apache和NGINX的性能,自己试试看吧。