3

Apach Bench 压测工具

 本篇主要讲解Apach Bench的基本使用 包括基本命令 和 对返回结果参数的详解,它可以很轻松的发送一些并发请求 ,ab命令可以创建很多的并发访问线程,模拟多个访问者同时对某一URL地址进行访问 是一款非常好用的工具。

 1.Mac版本无需下载

 如果你是Mac用户 那么恭喜 Mac电脑自带了Apach Bench工具,如果你是Windos用户那么请你面向百度 查询如何安装吧,我这里不做解释。

 2.基本命令讲解

Apache Bench 用法

 Usage: ab [options] [http[s]://]hostname[:port]/path

 options 有很多可选项这里我先说常用的几个(最下面会贴出所有的 options )

-n  发起的总请求数
-c  并发数(模拟多少客户端同时请求)
-t  测试所进行的最大秒数,限制测试在某时间内

 测试: 向百度发送 2000个请求,并发数200

ab -c 200 -n 2000 https://www.baidu.com/


johnny@localhost:~$ ab -c 200 -n 2000 https://www.baidu.com/
This is ApacheBench, Version 2.3 <$Revision: 1826891 $>
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)
Completed 200 requests
Completed 400 requests
Completed 600 requests
Completed 800 requests
Completed 1000 requests
Completed 1200 requests
Completed 1400 requests
Completed 1600 requests
Completed 1800 requests
Completed 2000 requests
Finished 2000 requests


Server Software:        BWS/1.1
Server Hostname:        www.baidu.com
Server Port:            443
SSL/TLS Protocol:       TLSv1.2,ECDHE-RSA-AES128-GCM-SHA256,2048,128
TLS Server Name:        www.baidu.com

Document Path:          /
Document Length:        227 bytes

Concurrency Level:      200         #并发数
Time taken for tests:   21.999 seconds   #完成这次测试的时间 既完成2000个请求的时间
Complete requests:      2000         #总请求数
Failed requests:        0         #失败数
Total transferred:      2163799 bytes     #整个场景中的网络传输量,表示所有请求的响应数据长度总和,包括Http头信息
HTML transferred:       454000 bytes     #整个场景中的HTML内容传输量,表示所有请求的响应数据中正文数 据的总和 不带Http头的
Requests per second:    90.91 [#/sec] (mean) #重点! 吞吐量 -> Complete requests / Time taken for tests = (2000 / 21.999)
Time per request:       2199.874 [ms] (mean) #重点! 每次并发(200) 执行完成的时间 总请求时间/(总请求数/并发数) = (21.999 / (2000/200) )
Time per request:       10.999 [ms] (mean, across all concurrent requests) #重点! 并发数内的每个请求的平均相应时间-> 每次并发执行总时间/并发数 = (2199.874/ 200 ) 
Transfer rate:          96.05 [Kbytes/sec] received

Connection Times (ms)
              min  mean[+/-sd] median   max
Connect:      216 1523 470.0   1519    2320
Processing:    34  480 449.2    346    1959
Waiting:       34  390 390.0    322    1653
Total:        308 2002 212.5   1930    3753

Percentage of the requests served within a certain time (ms)
 50%   1930    #50%的用户 相应时间小于 19毫秒
  66%   1989    
  75%   2063    
  80%   2224    #80%的用户 相应时间小宇 22毫秒
  90%   2287
  95%   2306
  98%   2670
  99%   2799
 100%   3753 (longest request)

返回结果重点部分:

Requests per second:    90.91 [#/sec] (mean) #重点! 吞吐量 -> Complete requests / Time taken for tests = (2000 / 21.999)
Time per request:       2199.874 [ms] (mean) #重点! 每次并发(200) 执行完成的时间 总请求时间/(总请求数/并发数) = (21.999 / (2000/200) )
Time per request:       10.999 [ms] (mean, across all concurrent requests) #重点! 并发数内的每个请求的平均相应时间-> 每次并发执行总时间/并发数 = (2199.874/ 200 ) 

 3.编写接口 使用Apache Bench 测试

private static int count = 0;
private static AtomicInteger atomicInteger = new AtomicInteger(0);

/**
 * 测试 count++
 */
@RequestMapping("/bench1")
public void bench2() throws InterruptedException {
    count++;
    Thread.sleep(100);
}

/**
 * 测试 ActomicInteger
 */
@RequestMapping("/bench2")
public void bench3() throws InterruptedException {
    atomicInteger.getAndIncrement();
    Thread.sleep(100);
}

/**
 * 打印最终的结果
 */
@RequestMapping("/printCount")
public void printCount() {
    log.info("【count: {}】", count);
    log.info("【AtomicCount: {}】", atomicInteger.get());
}

 第一个接口是 测试 count++
 第二个接口使 测试 ActomicInteger
 第三个接口使 打印 count和ActomicInteger的值

 分别对接口 1 和 2 发送 2000个请求 并发数200

Xnip20191214_173646.png

访问接口3 结果:
Xnip20191214_173920.png

 4.扩展Semaphore 和 CountDownLatch 模拟 ab并发请求

Semaphore 和 CountDownLatch 模拟 ab 发送2000个请求 200并发 ,不懂 Semaphore 和 CountDownLatch 自行百度吧。。。

  
 // 请求总数
    public static int clientTotal = 2000;

    // 同时并发执行的线程数
    public static int threadTotal = 200;
    // 信号量
    final Semaphore semaphore = new Semaphore(threadTotal);

    // 计数器闭锁
    final CountDownLatch countDownLatch = new CountDownLatch(clientTotal);

    for (int i=0;i<clientTotal;i++){
        executorService.execute(new Runnable() {
            @Override
            public void run() {
                try {
                    semaphore.acquire();
                    add();
                    semaphore.release();
                } catch (Exception e){
                    System.out.println(e);
                }
                // 每个线程执行时计数器都减1
                countDownLatch.countDown();
            }
        });
    }

 5.ab命令所有的 options 贴图

Options are:
-n requests         #执行的请求数,即一共发起多少请求。
-c concurrency      #请求并发数。
-t timelimit        #测试所进行的最大秒数。其内部隐含值是-n 50000,它可以使对服务器的测试限制在一个固定的总时间以内。默认时,没有时间限制。
-s timeout          #指定每个请求的超时时间,默认是30秒。
-b windowsize       #指定tcp窗口的大小,单位是字节。
-B address          #指定在发起连接时绑定的ip地址是什么。
-p postfile         #指定要POST的文件,同时要设置-T参数。
-u putfile          #指定要PUT的文件,同时要设置-T参数。
-T content-type     #指定使用POST或PUT上传文本时的文本类型,默认是'text/plain'。
-v verbosity        #设置详细模式等级。
-w                  #将结果输出到html的表中。
-i                  #使用HEAD方式代替GET发起请求。
-y attributes       #以表格方式输出时,设置html表格tr属性。 
-z attributes       #以表格方式输出时,设置html表格th或td属性。
-C attribute        #添加cookie,比如'Apache=1234'。(可重复)
-H attribute        #为请求追加一个额外的头部,比如'Accept-Encoding: gzip'。(可重复)
-A attribute        #对服务器提供BASIC认证信任。用户名和密码由一个:隔开,并以base64编码形式发送。无论服务器是否需要(即,是否发送了401认证需求代码),此字符串都会被发送。
-P attribute        #对一个中转代理提供BASIC认证信任。用户名和密码由一个:隔开,并以base64编码形式发送。无论服务器是否需要(即, 是否发送了401认证需求代码),此字符串都会被发送。
-X proxy:port       #指定代理服务器的IP和端口。
-V                  #打印版本信息。
-k                  #启用HTTP KeepAlive功能,即在一个HTTP会话中执行多个请求。默认时,不启用KeepAlive功能。
-d                  #不显示"percentage served within XX [ms] table"的消息(为以前的版本提供支持)。
-q                  #如果处理的请求数大于150,ab每处理大约10%或者100个请求时,会在stderr输出一个进度计数。此-q标记可以抑制这些信息。
-g filename         #把所有测试结果写入一个'gnuplot'或者TSV(以Tab分隔的)文件。此文件可以方便地导入到Gnuplot,IDL,Mathematica,Igor甚至Excel中。其中的第一行为标题。
-e filename         #产生一个以逗号分隔的(CSV)文件,其中包含了处理每个相应百分比的请求所需要(从1%到100%)的相应百分比的(以微妙为单位)时间。由于这种格式已经“二进制化”,所以比'gnuplot'格式更有用。
-r                  #当收到错误时不要退出。
-h                  #输出帮助信息
-Z ciphersuite      #指定SSL/TLS密码套件
-f protocol         #指定SSL/TLS协议(SSL3, TLS1, TLS1.1, TLS1.2 or ALL)




 5.总结

本篇主要讲解了Apache Bench的基本使用 以及对压测结果的返回进行分析 包括 吞吐量 平均并发请求时间等等 对于一些有并发的接口 可以自己测测 。。。

个人博客网站 https://www.askajohnny.com 欢迎来访问!
本文由博客一文多发平台 OpenWrite 发布!

Aska小强
100 声望6 粉丝