zoukankan      html  css  js  c++  java
  • [AapacheBench工具]web性能压力测试工具的应用与实践

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

    一、AB工具介绍:

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

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

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

    二、AB工具的获取:

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

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

    三、AB常用参数的介绍:

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

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

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

    -p:POST时的数据文件

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

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

    四、AB工具的使用实践:

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

    image

    命令解释:

    -n1000   执行请求数为1000个

    -c100      并发用户数为100个

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

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

    五、AB测试结果性能指标分析:

    测试结果返回如下:

    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’http://192.168.2.161:18080/ATS5S_CW/

  • 相关阅读:
    NuGet文件下载与应用
    两款Mongodb可视化工具
    原创 | 入门数据分析--SQL常用操作(+提取数据实例)
    原创 | 入门数据分析--数据存储之常用数据库及区别
    原创 | 入门数据分析--如何获取外部数据(+python爬虫实例)?
    原创 | 入门数据分析--如何建立需求解决框架?
    原创 | 入门数据分析--如何进行需求判定?
    原创 | 入门数据分析--如何更好的理解业务?
    原创 | 如何入门数据分析?
    原创 | 数据分析师的前景如何?
  • 原文地址:https://www.cnblogs.com/whylaughing/p/5435089.html
Copyright © 2011-2022 走看看