网站压力测试工具集合

    转自: http://www.yeolar.com/note/2012/11/24/web-bench-test/

    网站压力测试就是测试网站能够承受多大的访问量,以及在大访问量的情况下网站的性能。这些指标会直接影响用户的体验,因此在网站上线前一般都要做压力测试。压力测试也是考察网站使用的相关web服务器和框架的一个重要手段。

    因为和真实的环境不同,压力测试通过模拟得到的结果不会和实际的负载完全相同,但它仍是一个很好的基准比较。做压力测试时也会尽可能地模拟实际的情况。

    网上大家推荐的较为常见的网站压力测试工具有ab、webbench、http_load、siege、curl-loader、multi-mechanize、tcpcopy等。

    这里的大部分测试工具采用事件驱动模型来创建模拟用户,比如ab使用 apr 包中的 apr_pollset_poll 函数,而其他的工具都使用 select 函数,只有webbench通过 fork 子进程来创建模拟用户,它能模拟的并发数更高。

    我把大家的一些总结列在这里:

    ab

    Apache自带的压力测试工具,还有一个 独立版本 。主要用于测试网站的每秒处理请求数,多用于静态压力测试。基本用法是:

    $ ab n 1000 c 50 http://192.168.1.101/ n 总请求数 c 并发连接数

    输出的结果如下:

    Server Software: Apache/2.2.16 Server Hostname: 192.168.1.101 Server Port: 80 Document Path: / 请求文档路径 Document Length: 14643 bytes 请求文档大小 Concurrency Level: 50 并发数 Time taken for tests: 38.724 seconds 总测试时间 Complete requests: 1000 全部请求数 Failed requests: 14 失败请求数 (Connect: 0, Receive: 0, Length: 14, Exceptions: 0) Write errors: 14 Total transferred: 14847500 bytes 总数据传输量 HTML transferred: 14548500 bytes HTML数据传输量 Requests per second: 25.82 [#/sec] (mean) 平均每秒请求数 Time per request: 1936.210 [ms] (mean) 平均每次并发所有请求时间 Time per request: 38.724 [ms] (mean, across all concurrent requests) 平均每次请求时间 Transfer rate: 374.43 [Kbytes/sec] received 传输速率 Connection Times (ms) min mean[+/-sd] median max Connect: 2 668 1905.0 135 12237 连接时间 Processing: 0 1244 1652.3 902 14963 处理时间 Waiting: 0 1222 1651.1 883 14955 等待时间 Total: 134 1912 2723.5 1126 15096 Percentage of the requests served within a certain time (ms) 50% 1126 66% 1321 75% 1369 80% 1408 90% 1917 95% 10122 98% 13030 99% 13884 100% 15096 (longest request)

    webbench

    它主要测试每秒请求数,同时支持静态、动态和SSL,单例最多可模拟3万并发,适合小型网站的压力测试。

    基本用法是:

    $ webbench c 100 t 60 http://192.168.1.101/ c 并发数 t 测试时间

    测试结果如下:

    Benchmarking: GET http://192.168.1.101/ 100 clients, running 60 sec. Speed=1321 pages/min, 329214 bytes/sec. Requests: 1321 susceed, 0 failed.

    http_load

    http_load可以在 这里 下载。它可以以单一进程运行,还可以测试HTTPS类的网站。

    $ http_load p 100 s 60 urls.txt

    几个主要的参数是:

    • -p 并发数
    • -s 访问时间
    • -f 总访问次数
    • -r 每秒访问次数

    http_load把要测试的URL放在文件里。

    测试结果如下:

    1586 fetches, 100 max parallel, 2.32238e+07 bytes, in 60 seconds 14643 mean bytes/connection 26.4333 fetches/sec, 387063 bytes/sec
    msecs
    /connect: 4.47058 mean, 1109.64 max, 0.211 min
    msecs
    /firstresponse: 3652.73 mean, 29979.5 max, 234.175 min
    HTTP response codes
    : code 200 1586

    Siege

    Siege的主站为 http://www.joedog.org/siege-home/ 。它可以根据配置对一个网站做多用户并发访问,并记录每个用户所有请求过程的时间,可重复进行。

    Siege需要先生成一个配置文件.siegerc。它的测试URL也是写在一个文件中的,每行一个,从中随机访问。并且会生成一个log文件。

    $ siege c 100 r 10 f urls.txt c 并发数 r 重复次数

    在终端会输出:

    Transactions: 1000 hits 总次数 Availability: 100.00 % 成功率 Elapsed time: 15.77 secs 测试时间 Data transferred: 0.45 MB 总数据传输量 Response time: 0.47 secs 响应时间 Transaction rate: 63.41 trans/sec 每秒处理次数 Throughput: 0.03 MB/sec 每秒数据传输量 Concurrency: 29.90 实际最高并发数 Successful transactions: 1000 成功次数 Failed transactions: 0 失败次数 Longest transaction: 8.95 处理的最长时间 Shortest transaction: 0.04 处理的最短时间

    同时,siege.log文件中会记录本次测试的时间等信息。

    curl-loader

    curl-loader 的特点是它使用了libcurl和openssl的客户端协议栈(更为真实),还支持登录和验证行为。

    multi-mechanize

    multi-mechanize 是一个Python写的性能测试框架。它可以用Python库中的 urllib 、 httplib 来发起请求,也可以用libcurl来请求。可以和Mechanize集成,因此做单元测试很容易。另外,它还可以用matplotlib将测试结果生成比较直观的图表。

    tcpcopy

    前面的几种测试工具属于轻量级的,一般都是以单例来模拟多用户并发。 tcpcopy 基于底层应用请求复制,并且具有分布式压力测试的功能(本身有C/S架构),结果和实际数据较为接近,主要用于中大型的压力测试。基于TCP的包均可测试。

    转载请注明:软件测试 » 网站压力测试工具集合

    喜欢 0
标签: