HTTP 接口性能压力测试
一、前言
开发接口以后,对性能有要求的 接口,需要做 性能压力测试
常见免费的如:经典的 ab,性能不太好的 jmeter、siege(有时候都怀疑程序性能不行了),另介绍 hey、k6、vegeta、wrk
二、方案
1. ab - Apache HTTP server benchmarking tool
C 语言开发,适用于 Linux 平台
优劣:可能因为在 WSL 里面运行,性能表现不太好,容易报错,apr_pollset_poll: The timeout specified has expired (70007)
参数:c 并发数、n 总请求数、k 表示 开启 Keep Alive 特性、r 表示 忽略 socket receive errors
ab -c 100 -k -r -n 10000 http://www.a.com/a
2. hey: HTTP load generator, ab replacement
GO 语言开发,适用于 Linux、Mac、Windows 平台
性能高,跨平台,报表显示慢请求原因,最近发版是 2020 年
参数:c 并发数、z 测试时长
hey -c 50 -z 5s http://www.a.com/a
3. jmeter
Java 语言开发,适用于 多 平台
优劣:性能较差,跨平台
4. k6:load testing tool, using Go and JS
GO 语言开发,适用于 Linux、Mac、Windows 平台
参数:u 并发数、d 测试时长
需用 JavaScript 脚本 定义测试内容(如保存为 k6.js),
k6 run -u 200 -d 10s k6.js
5. siege
C 语言开发,适用于 Linux 平台
优劣:性能较低,不跨平台,报表没有显示慢请求原因
参数:c 并发数、t 测试时长(末尾单位必须大写)、b 表示 压测模式,请求不延迟(BENCHMARK: no delays between requests.)
siege -c 200 -t 10S -b http://www.a.com/a
6. vegeta
GO 语言开发,适用于 Linux、Mac、Windows 等 5 平台
优劣:性能高,跨平台,报表没有显示慢请求原因
参数:rate 指定并发,默认每秒 50 个请求,0 表示不限制(用于测试接口极限性能,需和 max-workers 参数一起使用)
另 workers 参数 指定 初始 workers 数量,默认为 10,设置和 max-workers 相等可避免测试过程中创建连接耗时
echo "GET http://www.a.com/a" | vegeta attack -rate 0 -workers 200 -max-workers 200 -duration 10s | vegeta report
7. wrk
C 语言开发,适用于 Linux 平台
优劣:性能超高,不跨平台,最近发版是 2021 年 2 月,另 WSL 里面运行卡住停不下来
t 线程数(不宜过大,避免太多上下文切换,CPU 核心数 1 到 3 倍左右),c 连接数,d 测试时长(末尾 s 表示秒),latency 输出延迟统计
wrk -t12 -c100 -d10s --latency http://www.a.com/a
三、总结
Open source load testing tool review 2020 (k6.io)
本文遵守【CC BY-NC】协议,转载请保留原文出处及本版权声明,否则将追究法律责任。
本文首先发布于 https://www.890808.xyz/ ,其他平台需要审核更新慢一些。
版权声明: 本文为 InfoQ 作者【javalover123】的原创文章。
原文链接:【http://xie.infoq.cn/article/533c64edb5c7964eb8d478055】。
本文遵守【CC BY-NC】协议,转载请保留原文出处及本版权声明。
评论