Mac下的Web性能压⼒测试⼯具:ab(ApacheBench)
Web开发,少不了的就是压⼒测试,它是评估⼀个产品是否合格上线的基本标准。
ab是⼀种⽤于测试Apache超⽂本传输协议(HTTP)服务器的⼯具。apache⾃带,可以测试Apache、IIS、Tomcat、Nginx等Web服务器,因为apache是跨平台的,所以在Mac、Linux、Windows等系统下,只要安装了apache就能使⽤ab⼯具。
Ubuntu系统安装测试⼯具:sudo apt-get install apache2-utils
CentOS系统安装测试⼯具:yum -y install httpd-tools
mac⾃带的apache中的ab是有最⼤并发限制的,您可以重新并且编译(可以参考),安装之前记得卸载原来的哦。
ab是⾮图形化的并发测试⼯具,没有Jmeter、Loadrunner那样有各种场景设计、各种图形报告和监控,只需⼀个命令即可,有输出描述,可以简单的进⾏⼀些压⼒测试。当然,您也可以选择webbench、siege、http_load、Load impact、阿⾥云PTS等⼯具进⾏很⽅便的测试。Mac下⾃带apache,查看版本:
apachectl -v
Server version: Apache/2.4.34 (Unix)
Server built:  Feb 22 2019 20:20:11
查看ab版本:
ab -V
ab压⼒测试⼯具的⽤法,查看:
ab --help
或者
man ab
# 按Ctrl+z组合键,或者按q键退出
例如:
ab -c 并发数 -n 请求数 URL
ab⼯具常⽤参数:
-n :总共的请求执⾏数,缺省是1;
-c:并发数,缺省是1;
-t:测试所进⾏的总时间,秒为单位,缺省50000s
-p:POST时的数据⽂件
-w: 以HTML表的格式输出结果
ab -n 100 -c 10 -w www.baidu/ >> baidu.html
# 结果界⾯和下⾯例⼦是⼀样的,只是以html⽂件形式保存⽽已。
下⾯,我们以请求百度为例:
ab -n 100 -c 10 www.baidu/
下⾯是运⾏结果:
/
/ apache版本信息
This is ApacheBench, Version 2.3 <$Revision: 1826891 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, ustech/
Licensed to The Apache Software Foundation, /
Benchmarking www.baidu (be patient)…..done
// 请求返回header类型
Server Software:        BWS/1.1
// 请求ip或者域名
Server Hostname:        www.baidu
// 请求端⼝,当前请求为https所以端⼝为443,请求https端⼝80
Server Port:            443
SSL/TLS Protocol:      TLSv1.2,ECDHE-RSA-AES128-GCM-SHA256,2048,128
TLS Server Name:        www.baidu
Document Path:          /
// 第⼀个成功返回的⽂档的字节⼤⼩
Document Length:        227 bytes
// 并发数
Concurrency Level:      10
// 从建⽴连接到最后接受完成总时间
Time taken for tests:  1.407 seconds
// 完成请求数
Complete requests:      100
/
/ 失败请求数
Failed requests:        0
// 从服务器接收的字节总数
Total transferred:      89300 bytes
// HTML接收字节数,减去了Total transferred中HTTP响应数据中的头信息的长度
nginx和apache区别
HTML transferred:      22700 bytes
// 吞吐率:每秒请求数(总请求数/总时间,相当于LR中的每秒事务数TPS)
Requests per second:    71.07【#/sec】(mean)
// ⽤户平均请求等待时间
Time per request:      140.709【ms】(mean)
// 服务器处理每个请求平均响应时间,mean表⽰为平均值
Time per request:      14.071 [ms] (mean, across all concurrent requests)
// 这些请求在单位时间内从服务器获取的数据长度
// 计算公式:Total trnasferred/ Time taken for tests
Transfer rate:          61.98 [Kbytes/sec] received
// 连接消耗时间分解
Connection Times (ms)
min  mean[+/-sd] median  max
最⼩值平均值标准差中间值最⼤值
Connect:      60  92  16.6    93    167
Processing:    18  32  11.2    30      97
Waiting:      18  30  9.9    30      97
Total:        77  124  21.4    122    208
// 按完成请求的百分⽐,得出完成请求中花费时间最长的那⼀个请求的时间,也就是这些请求完成时间的最⼤值(毫秒)
Percentage of the requests served within a certain time (ms)
// 50%请求完成时间的最⼤值是122毫秒
50%    122
66%    130
75%    139
80%    140
// 90%请求完成时间的最⼤值是148毫秒
90%    148
95%    164
98%    182
99%    208
// 100%请求完成时间的最⼤值是208毫秒(最长请求)
100%    208 (longest request)
ab性能指标
在进⾏性能测试过程中有⼏个指标⽐较重要。
1、吞吐率(Requests per second)
服务器并发处理能⼒的量化描述,单位是reqs/s,指的是在某个并发⽤户数下单位时间内处理的请求数。某个并发⽤户数下单位时间内能处理的最⼤请求数,称之为最⼤吞吐率。
记住:吞吐率是基于并发⽤户数的。这句话代表了两个含义:
a、吞吐率和并发⽤户数相关;
b、不同的并发⽤户数下,吞吐率⼀般是不同的。
计算公式:总请求数/处理完成这些请求数所花费的时间,即:
Request per second=Complete requests/Time taken for tests
必须要说明的是,这个数值表⽰当前机器的整体性能,值越⼤越好。
2、并发连接数(The number of concurrent connections)
并发连接数指的是某个时刻服务器所接受的请求数⽬,简单的讲,就是⼀个会话。
3、并发⽤户数(Concurrency Level)
要注意区分这个概念和并发连接数之间的区别,⼀个⽤户可能同时会产⽣多个会话,也即连接数。在HTTP/1.1下,IE7⽀持两个并发连接,IE8⽀持6个并发连接,FireFox3⽀持4个并发连接,所以相应的,我们的并发⽤户数就得除以这个基数。
4、⽤户平均请求等待时间(Time per request)
计算公式:处理完成所有请求数所花费的时间/(总请求数/并发⽤户数),即:Time per request=Time taken for tests/(Complete requests/Concurrency Level)
5、服务器平均请求等待时间(Time per request:across all concurrent requests)
计算公式:处理完成所有请求数所花费的时间/总请求数,即:
Time taken for/testsComplete requests
可以看到,它是吞吐率的倒数。同时,它也等于⽤户平均请求等待时间/并发⽤户数,即:
Time per request/Concurrency Level。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。