澳门新萄京官方网站-www.8455.com-澳门新萄京赌场网址

web质量压力测验工具的运用与实行,Apache自带压

2019-08-03 作者:服务器运维   |   浏览(87)

企业把其网站视为日常运作的关键业务。为了让关键业务的功能运作一直保持在最佳性能,Linux系统管理员需要多种工具来帮助他们简易有效地监控Web服务器。

企业把其网站视为日常运作的关键业务。为了让关键业务的功能运作一直保持在最佳性能,Linux系统管理员需要多种工具来帮助他们简易有效地监控Web服务器。

背景:网站性能压力测试是性能调优过程中必不可少的一环。服务器负载太大而影响程序效率是很常见的事情,一个网站到底能够承受多大的用户访问量经常是我们最关心的问题。因此,只有让服务器处在高压情况下才能真正体现出各个环节所暴露的问题。Apache中有个自带的,名为ab的程序,可以对Apache或其它类型的服务器进行网站访问压力测试。

ab命令原理 Apache的ab命令模拟多线程并发请求,测试服务器负载压力,也可以测试nginx、lighthttp、IIS等其它Web服务器的压力。
Apache附带的ab工具(使用的PHP环境是WAMP集成环境,ab工具位于D:wampbinapacheApache2.2.21bin)非常容易使用。ab命令对发出负载的计算机要求很低,既不会占用很多CPU,也不会占用太多的内存,但却会给目标服务器造成巨大的负载,因此是某些DDOS攻击之必备良药,老少皆宜。自己使用也须谨慎。否则一次上太多的负载,造成目标服务器直接因内存耗光死机,而不得不硬重启,得不偿失。

Apache自带压力测试工具——AB初体验

我们知道压力测试的软件确实很多,诸如微软的WAST,惠普的LoadRunner以及等等其他的,但这些软件学习起来还是需要花费些时间,在选择上实在头痛,后来在郭欣的那本《构建高性能Web站点》【PDF下载 】上看到了他介绍的这款Apache自带的压力测试工具AB,十分喜爱,于是今天终于有机会体验下ab对网站的压力测试。

    实验之前我的apache已经安装了,操作系统:Ubuntu 10.04 VMware 7.0

1、先查看一下版本信息 ab -V(注意是大写的V)
[email protected]:~$ ab -V 
02.This is ApacheBench, Version 2.3 <$Revision: 655654 $> 
03.Copyright 1996 Adam Twiss, Zeus Technology Ltd,  
04.Licensed to The Apache Software Foundation,  

 2、我们也可以使用小写的v查看下ab命令的一些属性 ab -v
[email protected]:~$ ab -v 
02.ab: option requires an argument -- v 
03.ab: wrong number of arguments 
04.Usage: ab [options] [http[s]://]hostname[:port]/path 
05.Options are: 
06.    -n requests    Number of requests to perform 
07.    -c concurrency  Number of multiple requests to make 
08.    -t timelimit    Seconds to max. wait for responses 
09.    -b windowsize  Size of TCP send/receive buffer, in bytes 
10.    -p postfile    File containing data to POST. Remember also to set -T 
11.    -u putfile      File containing data to PUT. Remember also to set -T 
12.    -T content-type Content-type header for POSTing, eg. 
13.                    'application/x-www-form-urlencoded' 
14.                    Default is 'text/plain' 
15.    -v verbosity    How much troubleshooting info to print 
16.    -w              Print out results in HTML tables 
17.    -i              Use HEAD instead of GET 
18.    -x attributes  String to insert as table attributes 
19.    -y attributes  String to insert as tr attributes 
20.    -z attributes  String to insert as td or th attributes 
21.    -C attribute    Add cookie, eg. 'Apache=1234. (repeatable) 
22.    -H attribute    Add Arbitrary header line, eg. 'Accept-Encoding: gzip' 
23.                    Inserted after all normal header lines. (repeatable) 
24.    -A attribute    Add Basic WWW Authentication, the attributes 
25.                    are a colon separated username and password. 
26.    -P attribute    Add Basic Proxy Authentication, the attributes 
27.                    are a colon separated username and password. 
28.    -X proxy:port  Proxyserver and port number to use 
29.    -V              Print version number and exit 
30.    -k              Use HTTP KeepAlive feature 
31.    -d              Do not show percentiles served table. 
32.    -S              Do not show confidence estimators and warnings. 
33.    -g filename    Output collected data to gnuplot format file. 
34.    -e filename    Output CSV file with percentages served 
35.    -r              Don't exit on socket receive errors. 
36.    -h              Display usage information (this message) 
37.    -Z ciphersuite  Specify SSL/TLS cipher suite (See openssl ciphers) 
38.    -f protocol    Specify SSL/TLS protocol (SSL2, SSL3, TLS1, or ALL) 

3、现在我们就对88181的网站进行一次压力测试吧,使用命令ab -n1000 -c10 -n1000 表示总请求数 -c10表示并发用户数为10 表示请求的URL,下面是测试的结果,其中我们最关心的三个指标,我已经注释出来了。

 
[email protected]:~$ ab -n1000 -c10  
02.This is ApacheBench, Version 2.3 <$Revision: 655654 $> 
03.Copyright 1996 Adam Twiss, Zeus Technology Ltd,  
04.Licensed to The Apache Software Foundation,  

  1. web质量压力测验工具的运用与实行,Apache自带压力测验工具。07.Benchmarking www.88181.com (be patient) 
    08.Completed 100 requests 
    09.Completed 200 requests 
    10.Completed 300 requests 
    11.Completed 400 requests 
    12.Completed 500 requests 
    13.Completed 600 requests 
    14.Completed 700 requests 
    15.Completed 800 requests 
    16.Completed 900 requests 
    17.Completed 1000 requests 
    18.Finished 1000 requests 
  2. /*WEB服务器用的是nginx*/
    21.Server Software:        nginx 
    22.Server Hostname:        www.88181.com 
    23.Server Port:            80
  3. 25.Document Path:          /index.php 
    26.Document Length:        154 bytes 
  4. 28.Concurrency Level:      10
    29.Time taken for tests:  74.373 seconds 
    30.Complete requests:      1000
    31.Failed requests:        0
    32.Write errors:          0
    33.Non-2xx responses:      1000
    34.Total transferred:      330000 bytes 
    35.HTML transferred:      154000 bytes
    36./*大家最关心的指标之一,指的是吞吐率
    37.相当于 LR 中的 每秒事务数 ,后面括号中的 mean 表示这是一个平均值*/ 
    38.Requests per second:    13.45 [#/sec] (mean)
    39./*大家最关心的指标之二,指的是用户平均请求等待时间
    40.相当于 LR 中的 平均事务响应时间 ,后面括号中的 mean 表示这是一个平均值*/
    41.Time per request:      743.726 [ms] (mean)
    42./*大家最关心的指标之三,指的是服务器平均请求处理时间
    43.Time per request:      74.373 [ms] (mean, across all concurrent requests) 
    44.Transfer rate:          4.33 [Kbytes/sec] received 
  5. 46.Connection Times (ms) 
    47.              min  mean[ /-sd] median  max 
    48.Connect:      129  163 245.3    145    3154
    49.Processing:  129  576 1510.8    147  11756
    web质量压力测验工具的运用与实行,Apache自带压力测验工具。50.Waiting:      129  567 1502.0    147  11756
    51.Total:        261  739 1543.7    294  11888
  6. 53.Percentage of the requests served within a certain time (ms) 
    54.  50%    294
    55.  66%    297
    56.  75%    304
    57.  80%    308
    58.  90%  1290
    59.  95%  3452
    60.  98%  7582
    61.  99%  7962
  7. 100%  11888 (longest request) 

4、为了使结果更有对比性,我们将并发用户更改为100个进行压力测试,我这里只将三个指标贴出来。
01.Requests per second:    190.95 [#/sec] (mean) 
02.Time per request:      523.694 [ms] (mean) 
03.Time per request:      5.237 [ms] (mean, across all concurrent requests) 

5、将并发用户改为200个进行测试
01.Requests per second:    186.00 [#/sec] (mean) 
02.Time per request:      1149.433 [ms] (mean) 
03.Time per request:      5.747 [ms] (mean, across all concurrent requests) 

6、500个并发用户时的情况
01.Requests per second:    180.99 [#/sec] (mean) 
02.Time per request:      2631.662 [ms] (mean) 
03.Time per request:      5.263 [ms] (mean, across all concurrent requests) 

我们来分析下测试的结果,先对比下吞吐率,当并发用户的时候吞吐率最高为190 reqs/s,当并发用户数为200,500 吞吐率下降了,随之用户的等待时间更是明显增加了,已经有2s的等待时间了。这说明性能明显下降了。当然分析这个测试结果并不是说明88181的网站的并发用户只能在500左右,因为我是在服务器负荷的情况下就行测试的,这显然不能说明问题。另外我们在生产环境下测试的时候,最好能将测试结果做成报表,这样可以非常清晰地对比出问题来,好了,我该准备下,给上面提交一份我们公司网站的测试报告了。

本文永久更新链接地址:

我们知道压力测试的软件确实很多,诸如微软的WAST,惠普的LoadRunner以及等等其他的,但这些软件学习...

以下三个开源工具可以帮助Linux管理员更进一步地理解他们的Web服务器的功能、潜在安全问题和访客人数:

以下三个开源工具可以帮助Linux管理员更进一步地理解他们的Web服务器的功能、潜在安全问题和访客人数:

一、AB工具介绍:

在带宽不足的情况下,最好是本机进行测试,建议使用内网的另一台或者多台服务器通过内网进行测试,这样得出的数据,准确度会高很多。远程对web服务器进行压力测试,往往效果不理想(因为网络延时过大或带宽不足)

1.用Apache Bench的测试性能基准。解决非预期性能下降的最好方法是确保它不在最初时发生。一个叫做Apache Benchab)的工具可以用于测试服务器的性能基准并优化其配置。

1.用Apache Bench的测试性能基准。

AB(ApacheBench) 是 Apache 自带的超文本传输协议 (HTTP) 网站性能压力测试工具。

下载安装:
找到 httpd-2.2.21-win32-x86-no_ssl.msi

Apache Bench的命令行界面很容易使用,系统管理员可以规定测试性能时应该现时发生的请求数量、POST净负荷或者包含有效性能结果的输出文件名。下面,你可以看看如何检查GameNomad开发服务器的性能,这能让你看到与在生产服务器上运行网站的对比性能:

解决非预期性能下降的最好方法是确保它不在最初时发生。一个叫做Apache Benchab)的工具可以用于测试服务器的性能基准并优化其配置。

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

参数文档:

该测试会发布总共1000个请求,同时执行10个请求:

Apache Bench的命令行界面很容易使用,系统管理员可以规定测试性能时应该现时发生的请求数量、POST净负荷或者包含有效性能结果的输出文件名。下面,你可以看看如何检查GameNomad开发服务器的性能,这能让你看到与在生产服务器上运行网站的对比性能:

ab命令对发出负载的计算机要求很低,既不会占用很高CPU,也不会占用很多内存,但却会给目标服务器造成巨大的负载,其原理类似CC攻击。自己测试使用也须注意,否则一次上太多的负载,可能造成目标服务器因资源耗完,严重时甚至导致死机。

运行: 在Windows系统下,打开cmd命令行窗口,定位到apache安装目录的bin目录下
cd C:Program Files Apache Software FoundationApache2.2bin

$ ab -c 10 -n 1000
...
Benchmarking stage.gamenomad.com (be patient)
Completed 100 requests
Completed 200 requests
...
Completed 900 requests
Completed 1000 requests
Finished 1000 requests

该测试会发布总共1000个请求,同时执行10个请求:

二、AB工具的获取:

键入命令:
ab -n 800 -c 800
(-n发出800个请求,-c模拟800并发,相当800人同时访问,后面是测试url)

Server Software:        Apache/2.2.17
Server Hostname:        stage.gamenomad.com
Server Port:            80

$ ab -c 10 -n 1000 http://stage.gamenomad.com/
...
Benchmarking stage.gamenomad.com (be patient)
Completed 100 requests
Completed 200 requests
...
Completed 900 requests
Completed 1000 requests
Finished 1000 requests
Server Software: Apache/2.2.17
Server Hostname: stage.gamenomad.com
Server Port: 80
Document Path: /
Document Length: 9654 bytes
Concurrency Level: 10
Time taken for tests: 376.074 seconds
Complete requests: 1000
Failed requests: 8
(Connect: 0, Receive: 0, Length: 8, Exceptions: 0)
Write errors: 0
Total transferred: 9988344 bytes
HTML transferred: 9596168 bytes
Requests per second: 10.91 [#/sec] (mean)
Time per request: 916.872 [ms] (mean)
Time per request: 91.687 [ms] (mean, across all concurrent requests)
Transfer rate: 106.58 [Kbytes/sec] received
Connection Times (ms)
min mean[ /-sd] median max
Connect: 88 96 9.7 94 151
Processing: 320 739 496.8 491 2640
Waiting: 221 629 494.2 376 2539
Total: 413 835 495.6 587 2735
Percentage of the requests served within a certain time (ms)
50% 587
66% 729
75% 942
80% 1528
90% 1672
95% 1761
98% 1924
99% 2735
100% 2735 (longest request)

1、工具是 Apache 自带的工具,安装了 Apache Http Server , 在 apache 的 Bin 目录下有 ab.exe 程序。

ab -t 60 -c 100
在60秒内发请求,一次100个请求。

Document Path:          /
Document Length:        9654 bytes

在信息返回到连接时间时,它把平均总连接时间分解成连接、等待和处理三个构成部分,并帮助识别潜在的瓶颈。

2、如果不想安装Apache 工具,可直接上网单独下载ab.exe

//如果需要在url中带参数,这样做
ab -t 60 -c 100 -T "text/plain" -p p.txt
p.txt 是和ab.exe在一个目录
p.txt 中可以写参数,如 p=wdp&fq=78

Concurrency Level:      10
Time taken for tests:   376.074 seconds
Complete requests:      1000
Failed requests:        8
   (Connect: 0, Receive: 0, Length: 8, Exceptions: 0)
Write errors:           0
Total transferred:      9988344 bytes
HTML transferred:       9596168 bytes
Requests per second:    10.91 [#/sec] (mean)
Time per request:       916.872 [ms] (mean)
Time per request:       91.687 [ms] (mean, across all concurrent requests)
Transfer rate:          106.58 [Kbytes/sec] received

尽管没有专用的最佳实践指标应用到每一种情况,最快的就是最好的。当页面下载缓慢时用户不会逗留。

三、AB常用参数的介绍:

澳门新萄京官方网站 1

Connection Times (ms)

改进之后,再次运行ab宁愿多试几次)并把结果和最初的进行对比。试想一下,对比的不只是连接时间还有不同时间内服务的要求比率。从远程服务器上运行ab尽可能的模仿真实世界的环境。

-n :总共的请求执行数,缺省是1;

澳门新萄京官方网站 2
结果参数解释:
This is ApacheBench, Version 2.3 <$Revision: 655654 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd,
Licensed to The Apache Software Foundation,

min  mean[ /-sd] median   max
Connect:       88   96   9.7     94     151
Processing:   320  739 496.8    491    2640
Waiting:      221  629 494.2    376    2539
Total:        413  835 495.6    587    2735

2.用Nikto评估服务器安全。

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

Benchmarking 192.168.0.10 (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
Finished 800 requests

Percentage of the requests served within a certain time (ms)
  50%    587
  66%    729
  75%    942
  80%   1528
  90%   1672
  95%   1761
  98%   1924
  99%   2735
 100%   2735 (longest request)

一般的网站类似于一个电子版的中世纪古堡,不断地有野蛮人在门上敲打。不同在于一个网站是全球规模的,所以一个自动化脚本或一些其它发明协同攻击你Web服务器防卫的机会更大。

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

Server Software: Microsoft-HTTPAPI/2.0 表示被测试的Web服务器软件名称
Server Hostname: 192.168.0.10 表示请求的URL主机名
Server Port: 80 表示被测试的Web服务器软件的监听端口

在信息返回到连接时间时,它把平均总连接时间分解成连接、等待和处理三个构成部分,并帮助识别潜在的瓶颈。

另外要采取积极措施,比如保持更新最新的安全补丁,把你自己当作潜在攻击者的位置并针对可能的安全问题扫描服务器都是有意义的。

-p:POST时的数据文件

Document Path: / 表示请求的URL中的根绝对路径,通过该文件的后缀名,我们一般可以了解该请求的类型
Document Length: 315 bytes 表示HTTP响应数据的正文长度

尽管没有专用的最佳实践指标应用到每一种情况,最快的就是最好的。当页面下载缓慢时用户不会逗留。

Nikto就是一种可用的工具,它是一个开源扫描器,它探查有关操作系统、Web服务器和软件安装的上千个已知漏洞。Nikto基于Perl,它可在包括Windows在内的所有操作系统上运行。一旦安装,扫描一个网站就像提起Nilto和你想扫描的服务器名字一样简单:

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

Concurrency Level: 800 表示并发用户数,这是我们设置的参数之一
Time taken for tests: 0.914 seconds所有这些请求处理完成所花费的时间
Complete requests: 800完成请求数
Failed requests: 0失败请求数
Write errors: 0
Non-2xx responses: 800
Total transferred: 393600 bytes网络总传输量
HTML transferred: 252000 bytes HTML内容传输量
Requests per second: 875.22 [#/sec] 吞吐量-每秒请求数
Time per request: 914.052 [ms] 服务器收到请求,响应页面要花费的时间
Time per request: 1.143 [ms] (mean, across all concurrent requests)并发的每个请求平均消耗时间
Transfer rate: 420.52 [Kbytes/sec] received 平均每秒网络上的流量,可以帮助排除是否存在网络流量过大导致响应时间延长的问题

改进之后,再次运行ab宁愿多试几次)并把结果和最初的进行对比。试想一下,对比的不只是连接时间还有不同时间内服务的要求比率。从远程服务器上运行ab尽可能的模仿真实世界的环境。

$ nikto -h dev.gamenomad.com

-i: 执行HEAD请求,而不是GET

网络上消耗的时间的分解:
Connection Times min mean[ /-sd] median max
Connect: 0 1 0.5 1 3
Processing: 245 534 125.2 570 682
Waiting: 11 386 189.1 409 669
Total: 246 535 125.0 571 684

2.用Nikto评估服务器安全。一般的网站类似于一个电子版的中世纪古堡,不断地有野蛮人在门上敲打。不同在于一个网站是全球规模的,所以一个自动化脚本或一些其它发明协同攻击你Web服务器防卫的机会更大。

尽管执行一次完全扫描不是一个坏主意,但记住,Nikto把综合性放在其它因素之前。这意味着它会执行上千次连续的请求。

四、AB工具的使用实践:

整个场景中所有请求的响应情况。在场景中每个请求都有一个响应时间
其中 50% 的用户响应时间小于 571 毫秒
80 % 的用户响应时间小于 652 毫秒
最大的响应时间小于 684 毫秒
Percentage of the requests served within a certain time
50% 571
66% 627
75% 646
80% 652
90% 666
95% 677
98% 681
99% 682
100% 684 (longest request)

另外要采取积极措施,比如保持更新最新的安全补丁,把你自己当作潜在攻击者的位置并针对可能的安全问题扫描服务器都是有意义的。

为此,你也许想要过滤Nikto的默认扫描范围。选择一个第三方安装包整合时可能已经进入的特定漏洞。检查执行已知SQL注入式攻击的能力和已安装软件的可见性,分别在-T标志后加入7和b值:

在cmd界面进入ab工具的目录,然后调用ab命令,编写测试用例命令:

这部分数据用于描述每个请求处理时间的分布情况,比如以上测试,80%的请求处理时间都不超过6ms,这个处理时间是指前面的Time per request,即对于单个用户而言,平均每个请求的处理时间。

Nikto就是一种可用的工具,它是一个开源扫描器,它探查有关操作系统、Web服务器和软件安装的上千个已知漏洞。Nikto基于Perl,它可在包括Windows在内的所有操作系统上运行。一旦安装,扫描一个网站就像提起Nilto和你想扫描的服务器名字一样简单:

$ nikto -h dev.gamenomad.com -T 7b
- Nikto v2.1.1
---------------------------------------------------------------------------
  Target IP: 127.0.0.1
  Target Hostname: dev.gamenomad.com
  Target Port: 80
  Start Time: 2011-08-03 13:05:22
---------------------------------------------------------------------------
  Server: Apache/2.2.17 (Ubuntu)
  No CGI Directories found (use ‘-C all’ to force check all possible dirs)
  Retrieved X-Powered-By header: PHP/5.3.5-1ubuntu7.2
  DEBUG HTTP verb may show server debugging information.
See http://msdn.microsoft.com/en-us/library/e8z01xdh(VS.80).aspx for details.
  21 items checked: 2 item(s) reported on remote host   End Time: 2011-08-03 13:07:59 (157 seconds)
---------------------------------------------------------------------------
  1 host(s) tested

澳门新萄京官方网站 3

$ nikto -h dev.gamenomad.com

记住,Nikto只可以连同第三方软件扫描报告的已知SQL注入式攻击。它无法侦测自定义应用里引入的SQL注入式攻击。

命令解释:

尽管执行一次完全扫描不是一个坏主意,但记住,Nikto把综合性放在其它因素之前。这意味着它会执行上千次连续的请求。

Nikto文件中有一个可用的完整漏洞选项列表,它包括的选项有创建报告、使用插件、运用超时压制请求等。

-n1000   执行请求数为1000个

为此,你也许想要过滤Nikto的默认扫描范围。选择一个第三方安装包整合时可能已经进入的特定漏洞。检查执行已知SQL注入式攻击的能力和已安装软件的可见性,分别在-T标志后加入7和b值:

3.用Piwik分析流量。

-c100      并发用户数为100个

$ nikto -h dev.gamenomad.com -T 7b

谷歌分析在Web分析时确实已经是龙头产品,但是其它分析工具也值得考虑。其中之一就是Piwik,它的目标是成为替代谷歌分析的开源选择。

http://192.168.2.161:18080/ATS5S_CW/     测试URL地址

- Nikto v2.1.1

  • Target IP:          127.0.0.1
  • Target Hostname:    dev.gamenomad.com
  • Target Port:        80
  • Start Time:         2011-08-03 13:05:22

  • Server: Apache/2.2.17 (Ubuntu)
  • No CGI Directories found (use ‘-C all’ to force check all possible dirs)
  • Retrieved X-Powered-By header: PHP/5.3.5-1ubuntu7.2
  • DEBUG HTTP verb may show server debugging information.
    See for details.
  • 21 items checked: 2 item(s) reported on remote host End Time:           2011-08-03 13:07:59 (157 seconds)

  • 1 host(s) tested

记住,Nikto只可以连同第三方软件扫描报告的已知SQL注入式攻击。它无法侦测自定义应用里引入的SQL注入式攻击。

Nikto文件中有一个可用的完整漏洞选项列表,它包括的选项有创建报告、使用插件、运用超时压制请求等。

3.用Piwik分析流量。谷歌分析在Web分析时确实已经是龙头产品,但是其它分析工具也值得考虑。其中之一就是Piwik,它的目标是成为替代谷歌分析的开源选择。

相比于AWStats和Webalizer等成熟的开源工具,Piwik还是一个新人,但是它平滑的界面、成熟的功能集、转换及电子商务追踪功能和可用于iOS和安卓的移动应用让它难以被忽视。

Piwik的安装和配置过程类似于谷歌分析,只需要在网站中插入追踪代码段的Java脚本。不同在于所有的分析信息都存储在本地的数据库中,在改变软件方面没有限制。

使用这三个开源解决方案可以更深刻地理解你的Web服务器的性能能力、潜在的安全问题和访客人数。  

...

相比于AWStats和Webalizer等成熟的开源工具,Piwik还是一个新人,但是它平滑的界面、成熟的功能集、转换及电子商务追踪功能和可用于iOS和安卓的移动应用让它难以被忽视。

>>d:test.txt    将结果输出到d盘的test文件中

Piwik的安装和配置过程类似于谷歌分析,只需要在网站中插入追踪代码段的Java脚本。不同在于所有的分析信息都存储在本地的数据库中,在改变软件方面没有限制。

澳门新萄京官方网站,五、AB测试结果性能指标分析:

使用这三个开源解决方案可以更深刻地理解你的Web服务器的性能能力、潜在的安全问题和访客人数。

测试结果返回如下:

原文地址:

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.2.161 (be patient)

Server Software:       
Server Hostname:        192.168.2.161 //域名   
Server Port:            18080//端口

Document Path:          /ATS5S_CW/ //请求的URL

Document Length:        5738 bytes//请求的文档大小

Concurrency Level:      100 //并发用户数
Time taken for tests:   2.923 seconds   //测试时间
Complete requests:      1000 //总的请求数
Failed requests:        0   // 失败的请求数
Write errors:           0   // 发送时失败的次数
Total transferred:      5941000 bytes  //字节数,包含http头信息
HTML transferred:       5738000 bytes  //字节数,实际页面传输的字节
Requests per second:    342.13 [#/sec] (mean) //平均每秒的请求数,相当于 LR 中的每秒事务数,也就是吞吐量

Time per request:       292.290 [ms] (mean)  //平均响应时间,相当于 LR 中的 平均事务响应时间
Time per request:       2.923 [ms] (mean, across all concurrent requests)  //平均处理时间,平均响应求时间除以并发数
Transfer rate:          1984.93 [Kbytes/sec] received  //传输速率,平均每秒的流量

Connection Times (ms)
              min  mean[ /-sd] median   max
Connect:        0    3   1.5      3       7                                        //socket发出请求到建立连接所花的时间50%的请求在289ms内返回
Processing:     6  274  51.8    286     323                          //连接建立后,直到http全部接收所用的时间
Waiting:        4  144  82.4    140     313                            //发送http完后,到接到第一个byte所等待的时间
Total:          7  277  51.8    289     325                                 //conn processing的时间

Percentage of the requests served within a certain time (ms)
  50%    289               //50%的请求在289ms内返回
  66%    296
  75%    300
  80%    302
  90%    307
  95%    311
  98%    316
  99%    320
100%    325 (longest request)

重要指标解释:

Requests per second:  平均每秒的请求数,即吞吐量,数值越大,服务端性能越好

Time per request:  平均响应时间,数值越小,服务端性能越好

Transfer rate: 传输速率,可以帮助排除是否存在网络流量过大导致响应时间延长的问题

 

六,AB工具使用进阶

1、发送post数据,需要设置-p和-T参数,如下

ab -n 1 -p post.txt  -T ‘application/x-www-form-urlencoded’

本文由澳门新萄京官方网站发布于服务器运维,转载请注明出处:web质量压力测验工具的运用与实行,Apache自带压

关键词: