HTTP接口性能压力测试

javalover123
• 阅读 428

一、前言

  • 开发接口以后,对性能有要求的 接口,需要做 性能压力测试
  • 常见免费的如:经典的 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
    HTTP接口性能压力测试

2. hey: HTTP load generator, ab replacement

  • GO语言开发,适用于 Linux、Mac、Windows 平台
  • 性能高,跨平台,报表显示慢请求原因,最近发版是 2020年
  • 参数:c 并发数、z 测试时长
  • hey -c 50 -z 5s http://www.a.com/a
    HTTP接口性能压力测试

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
    import http from "k6/http";
    import { check, sleep } from "k6";
    // Test configuration
    export const options = {
    };
    

export default function () { let res = http.get("url"); // check(res, { "status was 200": (r) => r.status == 200 }); }

```

HTTP接口性能压力测试

5. siege

  • C语言开发,适用于 Linux 平台
  • 优劣:性能较低,不跨平台,报表没有显示慢请求原因
  • 参数:c 并发数、t 测试时长(末尾单位必须大写)、b 表示 压测模式,请求不延迟(BENCHMARK: no delays between requests.)
  • siege -c 200 -t 10S -b http://www.a.com/a
    HTTP接口性能压力测试

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
    HTTP接口性能压力测试

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) | 工具 | RPS | 开发语言 | 支持平台 | 备注 | |:------------------------------------------- |:----- | --- |:-------- |:--------------------------------------------------------------- | | ab | 1929 | C | Linux | 可能因为在 WSL里面运行,性能不太好,容易报错 | | hey | 12000 | GO | 3平台 | 性能高,跨平台,报表显示慢请求原因,最近发版是2020年 | | jmeter | - | Java | 多平台 | 性能低,跨平台 | | k6 | 10000 | GO | 3平台 | 性能较高,跨平台,支持 请求、统计结果 校验,更适合自动化测试 | | siege | 2253 | C | Linux | 性能低,不跨平台,报表没有显示慢请求原因 | | vegeta | 10400 | GO | 5平台 | 性能高,跨平台,报表没有显示慢请求原因 | | wrk | - | C | Linux | 性能超高,不跨平台,最近发版是 2021年2月,另WSL里面运行没有效果 |

本文遵守【CC BY-NC】协议,转载请保留原文出处及本版权声明,否则将追究法律责任。
本文首先发布于 https://www.890808.xyz/ ,其他平台需要审核更新慢一些。

HTTP接口性能压力测试

点赞
收藏
评论区
推荐文章
liam liam
2年前
高效进行接口测试,简单易懂!
前言日常测试过程中,常常需要多种工具来接力完成自己的接口测试任务。比如说,使用swagger查看接口文档,使用mock编造接口数据对前端页面做测试使用postman测试后端接口,用Jmeter来做接口自动化测试/性能测试。那有没有一款软件可以完美集成以上所有的功能?笔者发现一款叫Apifox的软件,一款完成能完成以上几乎所有软件的功能。官方给出Apifox(
基于Spring Cache实现Caffeine、jimDB多级缓存实战
在早期参与涅槃氛围标签中台项目中,前台要求接口性能999要求50ms以下,通过设计Caffeine、ehcache堆外缓存、jimDB三级缓存,利用内存、堆外、jimDB缓存不同的特性提升接口性能,内存缓存采用Caffeine缓存,利用WTinyLFU算法获得更高的内存命中率;同时利用堆外缓存降低内存缓存大小,减少GC频率,同时也减少了网络IO带来的性能消耗;利用JimDB提升接口高可用、高并发;后期通过压测及性能调优999性能<20ms
Stella981 Stella981
3年前
Jmeter+jenkins如何快速搭建接口和性能测试持续集成解决方案
最近在用Jmeter本来想写一个详细的使用教程,突然看到有前辈已经写好了不错的教程,特此"借花献佛"整理出来分享给大家!JenkinsJmeter构建接口、性能测试持续集成解决方案  JenkinsJmeter可以很轻松的进行打包发布程序后自动进行接口冒烟测试,
Stella981 Stella981
3年前
Jmeter在windows上安装和环境配置
一、Jmeter简单介绍ApacheJMeter是Apache组织开发的基于Java的压力测试工具。它可以用于测试静态和动态资源,例如静态文件、Java小服务程序、CGI脚本、Java对象、数据库、FTP服务器,等等。JMeter可以用于对服务器、网络或对象模拟巨大的负载,来自不同压力类别下测试它们的强度和分析整体性能。另外,JMeter能够
Stella981 Stella981
3年前
Jmeter
性能测试最关键的一个方面是能够模拟应用程序的实际负载。但是,确定目标负载的并发用户数是不够的。在测试阶段使用的相同目标负载下,经过测试的应用程序可能会失败。或者当问题是系统中的瓶颈时,应用程序可能会在测试负载下失败。发生这些事情是因为除了目标负载之外,开发人员和性能测试人员还应该关心在测试执行期间如何分配负载也就是模拟各种负载压力场景。JMeter的Ra
Stella981 Stella981
3年前
Jmeter之java请求
ApacheJmeter是开源、易用的性能测试工具,之前工作中用过几次对http请求进行性能测试,对jmeter的基本操作有一些了解。最近接到开发的对java请求进行性能测试的需求,所以需要写java请求的脚本。Java请求的性能测试与http请求的性能测试类似,都是给远程应用提供的服务发送请求并施压,得到响应结果及性能数据。不同的是,http调用的是
Stella981 Stella981
3年前
2021最新版阿里巴巴Java性能调优速成手册强烈推荐
为什么要做性能调优?一款线上产品如果没有经过性能测试,那它就好比是一颗定时炸弹,你不知道它什么时候会出现问题,你也不清楚它能承受的极限在哪儿。所以,要不要做性能调优,这个问题其实很好回答。所有的系统在开发完之后,多多少少都会有性能问题,我们首先要做的就是想办法把问题暴露出来,例如进行压力测试、模拟可能的操作场景等等,再通过性能调
可莉 可莉
3年前
2021最新版阿里巴巴Java性能调优速成手册强烈推荐
为什么要做性能调优?一款线上产品如果没有经过性能测试,那它就好比是一颗定时炸弹,你不知道它什么时候会出现问题,你也不清楚它能承受的极限在哪儿。所以,要不要做性能调优,这个问题其实很好回答。所有的系统在开发完之后,多多少少都会有性能问题,我们首先要做的就是想办法把问题暴露出来,例如进行压力测试、模拟可能的操作场景等等,再通过性能调
十月飞翔 十月飞翔
2年前
AB(apache bench )简介-安装-使用
ab全称为:apachebenchab是Apache超文本传输协议(HTTP)的性能测试工具。其设计意图是描绘当前所安装的Apache的执行性能,主要是显示你安装的Apache每秒可以处理多少个请求。ab是apache自带的压力测试工具。ab非常实用,它不仅可以对apache服务器进行网站访问压力测试,也可以对或其它类型的服务器进行
存储接口测试简介与测试方法
接口测试原理是通过测试程序模拟客户端向服务器发送请求报文,服务端接收报文并处理后再把应答报文发送回客户端,客户端接收应答报文的过程测试接口目的就是保证接口调用的正确性和稳定性,测试内容概括为:功能、性能和安全,核心是持续集成
javalover123
javalover123
Lv1
10年Java经验,多个开源项目贡献者。https://github.com/javalover123
文章
16
粉丝
2
获赞
5