一、相关概念
与压力测试有关的概念:
- 吞吐率(Requests per second)
概念:服务器并发处理能力的量化描述,单位是 reqs/s,指的是某个并发用户数下单位时间内处理的请求数。某个并发用户数下单位时间内能处理的最大请求数,称之为最大吞吐率。
计算公式:总请求数 / 处理完成这些请求数所花费的时间,即
每秒请求数 = 完成请求数 / 测试时间。
- 并发连接数(并发连接数)
概念:某个时刻服务器所接受的请求数目,简单的讲,就是一个会话。
- 并发用户数(并发用户数,并发级别)
概念:要注意区分这个概念和并发连接数之间的区别,一个用户可能同时会产生多个会话,也即连接数。
- 用户平均请求等待时间(每个请求的时间)
计算公式:处理完成所有请求数所花费的时间 /(总请求数 / 并发用户数),即
每个请求的时间 = 测试所花费的时间 /(完整请求 / 并发级别)。
- 服务器平均请求等待时间(每个请求的时间:跨所有并发请求)
计算公式:处理完成所有请求数所花费的时间 / 总请求数,即所花费的时间 / 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
网友评论