3. 堪比JMeter的.Net压测工具 - Crank 进阶篇 - 认识bombardier
1. 前言
通过之前的学习,我们已经了解了各参数以及配置的意义,接下来的文章我们分别从bombardier以及wrk入手,进一步了解彼此之间的联系
2. 认识 bombardier
bombardier 是一个 HTTP(S) 基准测试工具。它是用 Go 编程语言编写的,并使用优秀的fasthttp代替 Go 的默认 http 库,因为它具有闪电般的快速性能,详细文档查看
其支持参数:
1 | -c, --connections=125 Maximum number of concurrent connections |
并且bombardier支持多平台,可以在Windows、Linux、OSX系统上运行,那接下来我们使用bombardier测试一下百度的压测情况
安装(WSL-Ubuntu):
1 | sudo apt install wget |
运行:
1 | ./bombardier-linux-arm64 -c 200 -d 1s --insecure -l https://www.baidu.com --print r --format json |
其中:
- req1xx代表http响应码为1**
- req2xx代表http响应码为2**
- req3xx代表http响应码为3**
- req4xx代表http响应码为4**
- req5xx代表http响应码为5**
- result.rps.mean代表每秒请求数
- result.rps.max代表每秒最大请求数
- result.latency.mean代表每毫秒延迟
- result.latency.max代表每毫秒最大延迟
3. 了解Microsoft.Crank.Jobs.Bombardier
在Microsoft.Crank.Jobs.Bombardier项目中Program.cs
- 根据参数获取-w、-d、-n、-f参数信息
- 校验压测时长、请求数等参数信息
- 判断当前运行环境是Windows、Linux、OSX,根据环境下载对应的bombardier,并根据传递的
- 根据yml参数最后拼装bombardier的原始命令:
bombardier -c 200 -d 1s –insecure -l https://www.baidu.com –print r –format json
- 将输出的结果使用追加到stringBuilder上,再赋值给output
- 通过JObject.Parse解析指标,最后通过BenchmarksEventSource存储并输出到控制台或数据库、csv、json中
其中
- 请求总数 = req1xx + req2xx + req3xx + req4xx + req5xx + others
- 成功请求数 = req2xx + req3xx
- 失败请求数 = 请求总数 - 成功请求数
1 | BenchmarksEventSource.Register("bombardier/requests;http/requests", Operations.Max, Operations.Sum, "Requests", "Total number of requests", "n0"); |
4. 解读bombardier.yml各参数作用
- connections: 最大并发连接数,默认: 256
- warmup: 预热时间,默认15s,与执行duration类似,而并非压测次数
- 当warmup > 0时,会先预热warmup秒后再执行一次压测,第二次的压测才是最后返回的结果
- 当warmup = 0时,不进行预热,直接开始压测
- duration: 测试时长,单位: s
- requests: 请求数
- rate: 每秒请求数限制
- transport: 传输方式。默认: fasthttp 、支持fasthttp、http1、http2三种
- presetHeaders: 预设header,根据全局参数headers,自选其一即可,选择json,那请求的header即为: –header “Accept: application/json,text/html;q=0.9,application/xhtml+xml;q=0.9,application/xml;q=0.8,/;q=0.7” –header “Connection: keep-alive”
- customHeaders: 自定义headers,如果预设headers中没有需要的header,则通过重写customHeaders,以完成自定义header的目的
- serverUri: 自定义url,如果此参数存在,则请求地址为: {serverUri}:{serverPort}{path}
- serverPort: 服务端口
- serverScheme: 服务的Scheme,默认http、支持http、https两种
- serverAddress: 服务地址、不包含http、例如: www.baidu.com,如果serverUri存在,此配置无效,如果不存在,请求格式为: {serverScheme}://{serverAddress}:{serverPort}{path}
- path: 服务接口地址,不包含域,例如: /api/check/healthy
- bodyFile: body内容,仅在非Get请求时使用,支持远程路径与本地绝对路径(Agent服务的绝对地址,非Controller端的绝对地址)
- verb: 请求方式: 默认GET、支持POST、PUT、DELETE、PATCH、GET
5. 总结
优势:
- 跨平台
- 用法简单
- 使用go语言开发、性能高
劣势:
- 不支持动态参数
- 不支持多个接口同时压测
bombardier.yml的存在是为Microsoft.Crank.Jobs.Bombardier提供配置参数,Microsoft.Crank.Jobs.Bombardier通过调用开源项目bombardier实现压测,并将压测结果通过BenchmarksEventSource存储并输出到控制台或数据库、csv、json中
源码地址:https://github.com/doddgu/crank/tree/sample
开源地址
MASA.BuildingBlocks:https://github.com/masastack/MASA.BuildingBlocks
MASA.Contrib:https://github.com/masastack/MASA.Contrib
MASA.Utils:https://github.com/masastack/MASA.Utils
MASA.EShop:https://github.com/masalabs/MASA.EShop
MASA.Blazor:https://github.com/BlazorComponent/MASA.Blazor
如果你对我们的 MASA Framework 感兴趣,无论是代码贡献、使用、提 Issue,欢迎联系我们
3. 堪比JMeter的.Net压测工具 - Crank 进阶篇 - 认识bombardier
https://blogs.masastack.com/2022/02/25/independent/crank/3. advancement 2/