7点微信公众号:请点这里。7点测试网QQ总群:277957570。

7点测试网

 找回密码
 注册7点

QQ登录

只需一步,快速开始

查看: 1763|回复: 2

ApacheBench压力测试工具使用介绍

[复制链接]
发表于 2013-6-26 16:34:11 | 显示全部楼层 |阅读模式
本帖最后由 Haines 于 2013-6-26 16:35 编辑

简介:
Apache Bench工具程序是Apache网站服务器软件的一个附带的工具软件,专门用来执行网站服务器的运行效能,特别是针对 Apache 网站服务器的效能分析。它可以同时模拟多个并发请求,测试Apache等Web服务器的最大承载压力,同时也可以根据Apache Bench提供的测试结果对服务器性能参数进行调整。
Apache Bench命令原理:
ab命令会创建很多的并发访问线程,模拟多个访问者同时对某一URL地址进行访问。它的测试目标是基于URL的,因此,既可以用来测试Apache的负载压力,也可以测试nginx、lighttpd、tomcat、IIS等其它Web服务器的压力。
ab命令对发出负载的计算机要求很低,既不会占用很高CPU,也不会占用很多内存,但却会给目标服务器造成巨大的负载,其原理类似CC攻击。自己测试使用也须注意,否则一次上太多的负载,可能造成目标服务器因资源耗完,严重时甚至导致死机。
Apache Bench相关使用说明:
Apache HTTP Server 网站下载最新版,如果你要在 Windows 的环境执行 ApacheBench 可以直接下载 Win32 Binary 的版本就好,由于在线所提供的版本是 MSI 的封装档,安装好之后也等同于在你的计算机内安装了一套 Apache HTTP Server,如果你不需要多执行一套 Apache HTTP Server 的话,你可以在安装好之后进入 C:\Program Files\Apache Group\Apache2\bin 目录,找到 ab.exe 执行档,复制出来后再移除 Apache 安装即可,因为 ab.exe 是可以独立执行的,不需要任何关连的 dll 。
Apache Bench参数说明:
格式:ab [options] [http://]hostname[:port]/path
           ab [选项][http://]主机[:端口]/路径
参数说明:
-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。它可以使对服务器的测试限制在一个固定的总时间以内。默认时,没有时间限制。

-p postfile File containing data to POST
//包含了需要POST的数据的文件,文件格式如“p1=1&p2=2”.使用方法是 -p 111.txt 。 (配合-T)
-T content-type Content-type header for POSTing
//POST数据所使用的Content-type头信息,如 -T “application/x-www-form-urlencoded” 。 (配合-p)

-v verbosity How much troubleshooting info to print
//设置显示信息的详细程度 – 4或更大值会显示头信息, 3或更大值可以显示响应代码(404, 200等), 2或更大值可以显示警告和其他信息。 -V 显示版本号并退出。

-w Print out results in HTML tables
//以HTML表的格式输出结果。默认时,它是白色背景的两列宽度的一张表

-i Use HEAD instead of GET
// 执行HEAD请求,而不是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. -C “c1=1234,c2=2,c3=3″ (repeatable)
//-C cookie-name=value 对请求附加一个Cookie:行。 其典型形式是name=value的一个参数对。此参数可以重复,用逗号分割。
提示:可以借助session实现原理传递 JSESSIONID参数, 实现保持会话的功能,如-C ” c1=1234,c2=2,c3=3, JSESSIONID=FF056CD16DA9D71CB131C1D56F0319F8″ 。

-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.
//-P proxy-auth-username:password 对一个中转代理提供BASIC认证信任。用户名和密码由一个:隔开,并以base64编码形式发送。无论服务器是否需要(即, 是否发送了401认证需求代码),此字符串都会被发送。

-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
-h Display usage information (this message)
//-attributes 设置属性的字符串. 缺陷程序中有各种静态声明的固定长度的缓冲区。另外,对命令行参数、服务器的响应头和其他外部输入的解析也很简单,这可能会有不良后果。它没有完整地实现 HTTP/1.x; 仅接受某些’预想’的响应格式。 strstr(3)的频繁使用可能会带来性能问题,即你可能是在测试ab而不是服务器的性能。

参数很多,一般我们用 -c 和 -n 参数就可以了。例如:

# ab -c 5000 -n 600 http://127.0.0.1/index.php
 楼主| 发表于 2013-6-26 16:34:55 | 显示全部楼层
本帖最后由 Haines 于 2013-6-26 16:38 编辑

一、下载、安装

Apache官方网站:http://httpd.apache.org/download.cgi
下载安装版本:Windows版本 httpd-2.2.22-win32-x86-no_ssl.msi
13655952028810.png

安装操作步骤:
1、采用默认安装方式,下一步即可,弹出下图,需要填入服务器信息,随便输入一下,以下三项可任意填写,无效的也行,第三项为邮箱作为反馈用户错误信息的;
13655952028821 (1).png

2、修改安装目录;

13655952028822.png
3、安装完成测试检查,访问在浏览器中输入“http://localhost/”或者输入“http://127.0.0.1/”,如果能够浏览到如下图所示:
13655952028833.png

二、使用说明

1、开始--->运行--->cmd,打开命令行,切换至安装目录下bin文件夹,例如我的安装目录如下:
微博桌面截图_20130617154654.jpg

2、开始简单的测试一下本机的服务:

输入:D:\Program Files\Apache Software Foundation\Apache2.2\bin>ab -k -n 1000 -c 100 h

ttp://192.168.1.61:8888/forum.php

3、打印出如下信息:

D:\Program Files\Apache Software Foundation\Apache2.2\bin>ab -k -n 1000 -c 100 http://192.168.1.61:8888/forum.php

This is ApacheBench, Version 2.3 <$Revision: 655654 $>

Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/

Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking 192.168.1.61 (be patient)

Completed 100 requests

Completed 200 requests

Completed 300 requests

Completed 400 requests

Completed 500 requests

Finished 500 requests

Server Software:        Apache/2.2.22              #Web服务器引擎

Server Hostname:        192.168.1.61               #服务器地址

Server Port:            8888                                  #服务器端口

Document Path:          /forum.php                #请求的文件路径

Document Length:        22273 bytes              #文件大小

Concurrency Level:      200                              #并发次数

Time taken for tests:   17.681 seconds           #测试所需时间

Complete requests:      500                             #成功请求次数

Failed requests:        0                                     #失败请求次数

Write errors:           0                                        #写入错误

Total transferred:      11497000 bytes              // 本次压力测试的总数据传输量(包括 HTTP Header 的数据也计算在内)

HTML transferred:       11136500 bytes           //本次压力测试的总数据传输量(仅计算回传的 HTML 的数据)

Requests per second:    28.28 [#/sec] (mean)   //平均返回数据时间

Time per request:       7072.405 [ms] (mean)     //平均响应时间(均值)

Time per request:       35.362 [ms] (mean, across all concurrent requests)   //平均并发请求时间

Transfer rate:          635.01 [Kbytes/sec] received                                           //平均每秒网络上的流量,可以帮助排除是否存在网络流量过大导致响应时间延长的问题

Connection Times (ms)                                                                              //压力测试时的联机处理时间

              min  mean[+/-sd] median   max

Connect:        2   19  28.5      8     232                                                        //网络连接状态

Processing:  2586 5336 1386.3   5826    7449                                           //网络处理状态

Waiting:     2009 5148 1461.6   5741    7413                                             //网络等待状态

Total:       2592 5356 1388.4   5837    7537

横轴字段的部分:
    * min:       最小值
    * mean:    平均值(正、负标准差)
    * median: 平均值(中间值)
    * max:      最大值

纵轴字段的部分:
    * Connect:     从 ab 发出 TCP 要求到 Web 主机所花费的建立时间。
    * Processing: 从 TCP 联机建立后,直到 HTTP 响应(Response)的数据全部都收到所花的时间。
    * Waiting:       从发送 HTTP 要求完后,到 HTTP 响应(Response)第一个 Byte 所等待的时间。
    * Total:           等于 Connect + Processing 的时间。(因为 Waiting 包含在 Processing 时间内了)



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

  50%   5837

  66%   6262

  75%   6529

  80%   6614

  90%   6813

  95%   6892

  98%   7034

  99%   7274

100%   7537 (longest request)

//整个场景中所有请求的响应情况。在场景中每个请求都有一个响应时间,其中50%的用户响应时间小于5837毫秒,66%的用户响应时间小于6262毫秒,最大的响应时间小于7537毫秒。对于并发请求,cpu实际上并不是同时处理的,而是按照每个请求获得的时间片逐个轮转处理的,所以基本上第一个Time per request时间约等于第二个Time per request时间乘以并发请求数。

总结:在远程对web服务器进行压力测试,往往效果不理想(因为网络延时过大),建议使用内网的另一台或者多台服务器通过内网进行测试,这样得出的数据,准确度会高很多。如果只有单独的一台服务器,可以直接本地测试,比远程测试效果要准确。

发表于 2014-10-31 15:46:46 | 显示全部楼层
ab可以单独运行,只用ab的话,其实没必要安装apache
您需要登录后才可以回帖 登录 | 注册7点

本版积分规则

QQ|Archiver|手机版|小黑屋|7点测试网 ( 京ICP备09084002号

GMT+8, 2018-8-15 15:44 , Processed in 0.137976 second(s), 22 queries .

Powered by Discuz! X3.1

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表