压力测试工具ab使用入门

554 阅读4分钟

mac本身自带了ab,但是有并发限制,如果有需要可以重新安装ab

其他系统安装说明

Ubuntu:sudo apt-get install apache2-utilsCentOS:yum -y install httpd-toolsWindows系统Apache下载地址:https://www.apachehaus.com/cgi-bin/download.plx

1、ab是什么?

ab是apache自带的压力测试工具,英文名apache bench。ab非常实用,它不仅可以对apache服务器进行网站访问压力测试,也可以对或其它类型的服务器进行压力测试。比如nginx、tomcat、IIS等。

2、大前端趋势下,前端时常也会有一些node的接口研发需求,本文简单记录一下用压力测试一个简单node服务

// index.js
const express = require('express');let app =express();//设置跨域访问app.all('*', function (req, res, next) {    res.header("Access-Control-Allow-Origin", "*");    res.header("Access-Control-Allow-Headers", "X-Requested-With");    res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");    res.header("X-Powered-By",' 3.2.1')    res.header("Content-Type", "application/json;charset=utf-8");    next()}); app.get('/', (req, res) => {    res.send('jone');});//配置服务端口var server = app.listen(8000, () => {    console.log( `localhost:8000`);});

(1) 执行node服务

node index.js

(2) 执行

ab -n 100 -c 10 http://localhost:8000/

ab -n 100 -c 10 http://localhost:8000/ >> jone.html

输出成为html文件展示

参数说明

ab工具常用参数:-n :总共的请求执行数,缺省是1;-c: 并发数,缺省是1;-t:测试所进行的总时间,秒为单位,缺省50000s-p:POST时的数据文件-w: 以HTML表的格式输出结果

result

// apache版本说明
This is ApacheBench, Version 2.3 <$Revision: 1843412 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/

Benchmarking localhost (be patient).....done
// 请求返回的header类型
Server Software:
// 请求url
Server Hostname:        localhost
// 端口号
Server Port:            8000

Document Path:          /
// 第一个成功返回的文档的字节
Document Length:        4 bytes

// 并发数量
Concurrency Level:      10
// 从建立连接到最后完成接受的总时间
Time taken for tests:   0.038 seconds
// 总共完成的请求数
Complete requests:      100
// 失败的请求数
Failed requests:        0
// 从服务器接收的总字节数
Total transferred:      46300 bytes
// HTML接收字节数,减去了Total transferred中HTTP响应数据中的头信息的长度
HTML transferred:       400 bytes
// rps(吞吐率)
Requests per second:    2613.01 [#/sec] (mean)
// tpr(用户平均请求等待时间)
Time per request:       3.827 [ms] (mean)
// 服务器处理单个请求的平均时间 mean 表示平均
Time per request:       0.383 [ms] (mean, across all concurrent requests)
// 这些请求在单位时间内从服务器获取的数据长度 
// 计算公式:Total trnasferred/ Time taken for testsTransfer rate:          1181.47 [Kbytes/sec] received
// 连接消耗时间分解
Connection Times (ms)
              min  mean[+/-sd] median   max
              最小值 平均值 标准差  中间值    最大值Connect:        0    0   0.1      0       0
Processing:     1    4   1.0      3       6
Waiting:        0    2   0.8      2       5
Total:          1    4   1.1      3       6
//按完成请求的百分比,得出完成请求中花费时间最长的那一个请求的时间,也就是这些请求完成时间的最大值(毫秒)
Percentage of the requests served within a certain time (ms)
  50%      3
  66%      4
  75%      4
  80%      5
  90%      6
  95%      6
  98%      6
  99%      6
 100%      6 (longest request)
//100%请求完成时间的最大值是208毫秒(最长请求)

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