Apache Bench——ab 性能测试工具

一、相关概念
与压力测试有关的概念:

  1. 吞吐率(Requests per second)

概念:服务器并发处理能力的量化描述,单位是 reqs/s,指的是某个并发用户数下单位时间内处理的请求数。某个并发用户数下单位时间内能处理的最大请求数,称之为最大吞吐率。
计算公式:总请求数 / 处理完成这些请求数所花费的时间,即
每秒请求数 = 完成请求数 / 测试时间。

  1. 并发连接数(并发连接数)

概念:某个时刻服务器所接受的请求数目,简单的讲,就是一个会话。

  1. 并发用户数(并发用户数,并发级别)

概念:要注意区分这个概念和并发连接数之间的区别,一个用户可能同时会产生多个会话,也即连接数。

  1. 用户平均请求等待时间(每个请求的时间)

计算公式:处理完成所有请求数所花费的时间 /(总请求数 / 并发用户数),即
每个请求的时间 = 测试所花费的时间 /(完整请求 / 并发级别)。

  1. 服务器平均请求等待时间(每个请求的时间:跨所有并发请求)

计算公式:处理完成所有请求数所花费的时间 / 总请求数,即所花费的时间 / testsComplete 请求。
可以看到,它是吞吐率的倒数。
同时,它也 = 用户平均请求等待时间 / 并发用户数,即
每个请求的时间 / 并发级别。

二、什么是 Apache Bench

官网地址:ab - Apache HTTP server benchmarking tool

ab - Apache HTTP 服务器性能基准工具。

AB 是 Apache 的超文本传输协议(HTTP)的性能测试工具。其设计意图是描绘当前所安装的的 Apache 的执行性能,主要是显示你安装的 Apache 的每秒可以处理多少个请求。

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

ab 是一种用于测试 Apache 超文本传输协议(HTTP)服务器的工具。apache 自带 ab 工具,可以测试
apache、IIs、tomcat、nginx 等服务器。但是 ab 没有 Jmeter、Loadrunner 那样有各种场景设计、各种图形报告和监控,只需一个命令即可,有输出描述,可以简单的进行一些压力测试。

总的来说 ab 工具 ab 小巧简单,上手学习较快,可以提供需要的基本性能指标,但是没有图形化结果,不能监控。因此 ab 工具可以用作临时紧急任务和简单测试。
同类型的压力测试工具还有:webbench、siege、http_load 等

三、使用

查看 Apache 版本

Mac 系统下自带 Apache,可以使用 apachectl -v 命令查看 Apache 版本:

$ apachectl -v
Server version: Apache/2.4.34 (Unix)
Server built:   Aug 17 2018 18:35:43

查看 ab 版本

$ ab -V   # 注意到,这里是大写的V
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/

查看当前系统的默认文件打开数:

ulimit -a
-t: cpu time (seconds)              unlimited
-f: file size (blocks)              unlimited
-d: data seg size (kbytes)          unlimited
-s: stack size (kbytes)             8192
-c: core file size (blocks)         0
-v: address space (kbytes)          unlimited
-l: locked-in-memory size (kbytes)  unlimited
-u: processes                       1418
-n: file descriptors                4864

设置打开文件数限制为 2048:

ulimit -n 2048

测试命令

命令行参数 说明
-n 请求次数
-c 并发数
-r 当接收到错误时,不要退出套接字(socket)

错误问题:apr_socket_connect(): Operation already in progress (37)

这一个问题解决就是

ulimit -u 5000(16GB内存)
ulimit -u 2030(8G内存)

错误问题: apr_socket_recv: Connection reset by peer (54)

这个报错一般是由于使用的 MacOSX 默认自带的 ab 限制了并发数导致的。
解决办法:下载最新的 apache 并重新编译,备份原来的 ab 并将新编译的 ab 替换到原来的路径

错误问题: apr_socket_recv: Connection Time out(60)&&socket: Too many open files (24)

这个的话就先更改最大文件限制

ulimit -n (查看是多少)
ulimit -n number(填数字设置最大值)

ab 压测试时再添加上-s (你的需要的数字ms) 即可以解决timeout的问题

ab -s 1000 -r -k -n 10000 -c 500 -p Desktop/postab.txt -T 'application/json' "url"

以上内容大部分转自https://www.jianshu.com/p/14ed545ccf56,因为大同小异所以笔者没有自己写.错误问题可以看看,然后分享一个重装ab的连接https://www.jianshu.com/p/2fe5b906feb1

你可能感兴趣的:(Apache Bench——ab 性能测试工具)