基准测试工具ab命令学习
-
- [1. ab命令介绍](#1. ab命令介绍)
- [2. ab常用参数介绍](#2. ab常用参数介绍)
- [3. 实战测试](#3. 实战测试)
1. ab命令介绍
ab是 Apache HTTP 服务器基准测试工具,单也常被用于评估 Web 服务器在不同负载下的性能表现,如吞吐量、响应时间、并发处理能力等。它通过模拟多用户并发请求,生成详细的性能报告。
2. ab常用参数介绍
| 参数 | 含义 | 示例场景 |
|---|---|---|
| -n <请求数> | 总请求数量(必须指定) | -n 1000 表示共发送 1000 次请求 |
| -c <并发数> | 并发请求数量(同时发起的请求数) | -c 100 表示每次 100 个并发 |
| -t <秒数> | 测试超时时间(默认不限时,此参数优先级高于 -n) | -t 60 表示测试最多持续 60 秒 |
| -s <秒数> | 单个请求的超时时间(默认 30 秒) | -s 10 表示单个请求最多等 10 秒 |
| -p <文件> | 发送 POST 请求的数据文件(需配合 -T) | -p data.json 表示 POST 文件内容 |
| -T <类型> | 指定 POST/PUT 的 Content-Type | -T application/json 表示 JSON 格式 |
| -k | 启用 HTTP 长连接(Keep-Alive) | 测试支持长连接的服务(如 API) |
| -H <头信息> | 自定义请求头(可重复添加) | 添加 Token、User-Agent 等 |
| -C | 添加 Cookie(可重复添加) | 模拟登录状态的请求 |
| -A <账号:密码> | 基本 HTTP 认证(用户名:密码) | 测试需要登录的受保护接口 |
| -w | 以 HTML 表格形式输出结果 | 便于保存为网页查看 |
| -g <文件> | 生成 gnuplot 格式数据文件(可绘图) | 用于生成性能趋势图 |
| -e <文件> | 生成 CSV 文件(包含响应时间百分比分布) | 用于 Excel 分析响应延迟分布 |
3. 实战测试
我的配置是1c2g
安装nginx
dnf -y install nginx
systemctl start nginx
发送1w的请求数、每次1k的并发:
ab -n 10000 -c 1000 http://127.0.0.1/
clike
This is ApacheBench, Version 2.3 <$Revision: 1913912 $>
Copyright 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Licensed to The Apache Software Foundation, http://www.apache.org/
Benchmarking 127.0.0.1 (be patient)
Completed 1000 requests
Completed 2000 requests
Completed 3000 requests
Completed 4000 requests
Completed 5000 requests
Completed 6000 requests
Completed 7000 requests
Completed 8000 requests
Completed 9000 requests
Completed 10000 requests
Finished 10000 requests
Server Software: nginx/1.20.1 # 软件版本
Server Hostname: 127.0.0.1 # 访问地址
Server Port: 80 # 端口
Document Path: / # 访问路径
Document Length: 7620 bytes # 页面大小
Concurrency Level: 1000 # 并发数
Time taken for tests: 0.723 seconds #
Complete requests: 10000 # 共完成 10000 次请求
Failed requests: 128 # 失败请求
(Connect: 0, Receive: 0, Length: 64, Exceptions: 64)
Total transferred: 78047280 bytes
HTML transferred: 75712320 bytes
Requests per second: 13827.80 [#/sec] (mean) # 每秒请求数,核心吞吐量指标,数值越高说明服务处理能力越强。
Time per request: 72.318 [ms] (mean) # 单个用户发起请求到收到响应的平均时间,在1000并发下
Time per request: 0.072 [ms] (mean, across all concurrent requests) # 对所有并发即 1000 个并发请求的平均分摊延迟
Transfer rate: 105392.77 [Kbytes/sec] received # 传输速率
Connection Times (ms) # 连接耗时
min mean[+/-sd] median max
Connect: 0 33 5.2 33 52
Processing: 6 37 7.6 35 64
Waiting: 0 29 6.6 28 50
Total: 26 70 8.0 69 97
Percentage of the requests served within a certain time (ms) # 百分比延迟分布
50% 69
66% 70
75% 71
80% 72
90% 82
95% 86
98% 88
99% 88
100% 97 (longest request)