• 【性能测试工具】- ApacheBench


    优点:提供的测试结果信息更完备;缺点:每次只能测试一个链接

    概述:

    ab全称是ApacheBench,是 Apache 附带的一个HTTP性能测试小工具,可以同时模拟多个并发请求。

    安装:

    Apache服务器套件自带ab,只要安装Apache即可,无需另行安装ab。ab位于%ApacheHome%/bin目录下(“%ApacheHome%”为Aapche安装路径),你也可以把ab.exe文件copy出来,独立使用。

    基本使用:

    访问www.baidu.com首页,同时处理5个并发请求,并且运行10次访问baidu首页。            /*性能测试需求*/

    XXXXXXXX:~$ ab -n 10 -c 5 http://www.baidu.com/

    /*启动apache ab,向www.baidu.com 总共发送10个请求(-n 10),1次发送5个(-c 5),也就是说发给www.baidu.com的请求分两批发完的。*/

    操作结果:

    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 www.baidu.com (be patient).....done

    Server Software:        BWS/1.0

    Server Hostname:        www.baidu.com

    Server Port:            80

    Document Path:          /

    Document Length:        9777 bytes

    Concurrency Level:      5                                                        /*并发数*/

    Time taken for tests:   0.017 seconds                     /*整个测试持续的时间*/

    Complete requests:      10                                       /*完成的请求数量*/

    Failed requests:        2                                            /*失败的请求数量*/

       (Connect: 0, Receive: 0, Length: 2, Exceptions: 0)

    Write errors:           0

    Total transferred:      101688 bytes                     /*整个场景中的网络传输量*/

    HTML transferred:       97786 bytes                  /*整个场景中的html内容传输量*/

    /*大家最关心的指标之一,指的是吞吐率

    相当于 LR 中的 每秒事务数 ,后面括号中的 mean 表示这是一个平均值*/

    Requests per second:    584.39 [#/sec] (mean)    /*每秒事务数,mean表示这是一个平均值*/

    /*大家最关心的指标之二,指的是用户平均请求等待时间

    相当于 LR 中的 平均事务响应时间 ,后面括号中的 mean 表示这是一个平均值*/ 

    Time per request:       8.556 [ms] (mean)                   /*每1次包含5个并发的请求时间*/

    //大家最关心的指标之三,指的是服务器平均请求处理时间

    Time per request:       1.711 [ms] (mean, across all concurrent requests)               /*5个并发数,其中每一个请求的时间*/

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

    Connection Times (ms)

                  min  mean[+/-sd] median   max

    Connect:        0    0   0.1      0       0                      //网络连接状态

    Processing:      5    7   1.6      7      10                      //网络处理状态

    Waiting:        4    6   1.6      6       9                       //网络等待状态

    Total:          5    7   1.6      7      10          /*这4行显示的是网络上消耗的时间的分解*/

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

      50%      7

      66%      7

      75%      7

      80%     10

      90%     10

      95%     10

      98%     10

      99%     10

     100%     10 (longest request)                  /*这些内容显示的是整个场景中所有请求的响应情况,

    在场景中每个请求都有一个响应时间,其中75%的用户响应时间小于7毫秒,最大响应时间小于10毫秒*/

    参数说明:

    http://httpd.apache.org/docs/2.0/programs/ab.html

    -A auth-username:password
    向服务器提供基本认证信息。用户名和密码之间由一个":"隔开,并将被以base64编码形式发送。无论服务器是否需要(即是否发送了401认证需求代码),此字符串都会被发送。

    -c concurrency
    一次产生的请求个数。默认是一次一个。

    -C cookie-name=value
    对请求附加一个"Cookie:"头行。其典型形式是 name=value 的一个参数对。此参数可以重复。

    -d
    不显示"percentage served within XX [ms] table"消息(为以前的版本提供支持)。

    -e csv-file
    产生一个逗号分隔(CSV)文件,其中包含了处理每个相应百分比请求(从1%到100%)所需要的相应百分比时间(以微秒为单位)。由于这种格式已经"二进制化",所以比"gnuplot"格式更有用。

    -g gnuplot-file
    把所有测试结果写入一个"gnuplot"或者TSV(以Tab分隔)文件。此文件可以方便地导入到 Gnuplot, IDL, Mathematica, Excel中。其中的第一行为标题。

    -h
    显示使用方法的帮助信息。

    -H custom-header
    对请求附加额外的头信息。此参数的典型形式是一个有效的头信息行,其中包含了以冒号分隔的字段和值(如:"Accept-Encoding: zip/zop;8bit")。

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

    -k
    启用KeepAlive功能,即在一个HTTP会话中执行多个请求。默认不启用KeepAlive功能。

    -n requests
    在测试会话中所执行的请求个数。默认仅执行一个请求,此时其结果不具有意义。

    -p POST-file
    包含了POST数据的文件。

    -P proxy-auth-username:password
    对一个中转代理提供基本认证信息。用户名和密码由一个":"隔开,并将被以base64编码形式发送。无论服务器是否需要(即是否发送了407代理认证需求代码),此字符串都会被发送。

    -q
    如果处理的请求数大于150,ab每处理大约10%或者100个请求时,会在stderr输出一个进度计数。此 -q 标记可以屏蔽这些信息。

    -s
    用于编译中(ab -h 会告诉你)使用了SSL的受保护的https ,而不是http协议的时候。此功能是实验性的,最好不要用。

    -S
    不显示中值和标准偏差值,而且在均值和中值为标准偏差值的1到2倍时,也不显示警告或出错信息。默认时,会显示最小值/均值/最大值等数值。(为以前的版本提供支持)

    -t timelimit
    测试所进行的最大秒数。内部隐含值是"-n 50000"。它可以使对服务器的测试限制在一个固定的总时间以内。默认时,没有时间限制。

    -T content-type
    POST数据时所使用的"Content-type"头信息。

    -v verbosity
    设置显示信息的详细程度,4或更大值会显示头信息,3或更大值可以显示响应代码(404,200等),2或更大值可以显示警告和其他信息。

    -V
    显示版本号并退出。

    -w 

    以HTML表格形式输出结果。默认时,它是白色背景的两列宽度的一张表。 

    -x <table>-attributes 

    设置<table>属性的字符串。此属性被填入<table 这里 > 。

    -X proxy[:port]
    对请求使用代理服务器。

    -y <tr>-attributes
    设置<tr>属性的字符串。

    -z <td>-attributes
    设置<td>属性的字符串。

    讨论/疑问:

    • Ab的启动时间会有延时,比如设置的执行时间是5秒(-t 5),执行ab -n 1000 -c 2 -t 5 http://www.baidu.com/,那么在执行结果内查看测试的持续时间则是“Time taken for tests:   7.657 seconds”。则启动时间消耗了2秒。
    • www.douban.com/测试,首次没有失败的请求,后几次会有失败的请求,这个可能是网站的保护机制吧?
  • 相关阅读:
    libevent-2.0.so.5 (安装MEMCACHED问题)
    MySQL的show语句大全
    远程客户端连接MysqL数据库太慢解决方案
    用SQL命令查看Mysql数据库大小
    elasticsearch-head安装及启动
    logstash收集IIS日志
    备份并删除7天以前数据
    shell脚本递归压缩实践
    二目运算符 “->”
    关于int main( int argc, char *argv[] )
  • 原文地址:https://www.cnblogs.com/musicmovie/p/3919963.html
Copyright © 2020-2023  润新知