基于 go-wrk 在 Windows 环境下对 Go Web 应用进行 HTTP 压力测试

基于 go-wrk 在 Windows 环境下对 Go Web 应用进行 HTTP 压力测试

这部分内容参考并搬运自 q1mi 老师的技术博客,原文的链接为:https://liwenzhou.com/posts/Go/benchmark-tools/

压测相关术语

  • 响应时间(RT):指系统对请求(Request)做出响应的时间;
  • 吞吐量(Throughout):指系统在单位时间内处理请求的数量
  • QPS每秒查询率(Query Per Second):指一台服务器每秒能够响应的查询次数 ,是对一个查询服务器在规定时间内所处理流量多少的衡量标准
  • TPS(Transaction Per Second):每秒钟系统能够处理的交易或事物的数量
  • 并发连接数:某个时刻服务器所接受的请求总数

go-wrk

q1mi 老师在博客中提到了 ab 和 wrk 等压测工具,由于我使用的开发环境是 windows,可以直接使用 go-wrk 来进行压测(但是一般压测都应该是在服务器,go-wrk 在 linux 服务器上应该也可以工作)。

首先安装 go-wrk:

go 复制代码
go get github.com/adeven/go-wrk

如果想要在 windows 的 terminal 当中使用 go 的包,那么首先需要在本地 gopath 路径下的 pkg 中找到这个包存放的位置,之后使用:

go 复制代码
go mod init .
go build

会生成一个可执行文件,再将这个文件夹的地址添加到 windows 的环境变量当中,即可在 terminal 直接使用 go-wrk 命令进行压测。【支持 GIN 框架热重载的 Air 工具也可以使用相同的方法来在 terminal 使用,此外,将地址添加到环境变量之后,应该重启 terminal,如果是在 Goland 这类 IDE 当中使用 terminal,那么请直接重启 Goland】

此时在命令行直接使用 go-wrk 命令,会显示提示信息,表示安装成功。

go-wrk 的使用方法与 wrk 类似,基本格式如下:

go 复制代码
go-wrk [flags] url

常用的参数:

go 复制代码
-H="User-Agent: go-wrk 0.1 bechmark\nContent-Type: text/html;": 由'\n'分隔的请求头
-c=100: 使用的最大连接数
-k=true: 是否禁用keep-alives
-i=false: if TLS security checks are disabled
-m="GET": HTTP请求方法
-n=1000: 请求总数
-t=1: 使用的线程数
-b="" HTTP请求体
-s="" 如果指定,它将计算响应中包含搜索到的字符串s的频率

一个使用 go-wrk 执行压测的例子如下,本例当中我直接对 bluebell 项目进行压测:

首先使用 air 在命令行启动 bluebell 项目,并在 8081 端口监听服务:

之后新开一个 terminal,使用 go-wrk 对 posts 这个 api 进行压测:

go 复制代码
go-wrk -t=8 -c=100 -n=10000 "http://127.0.0.1:8081/api/v1/posts"
# 127.0.0.1 是本机的 IP 地址, 8081 是 GIN 监听的端口号, 请按照自己程序当中的配置设置

压测的结果:

当然,进行压测的方式也是对端口发送请求,在 air 端可以查看日志:

至此,根据 q1mi 老师的技术博客,我们了解了服务器性能的基本指标,了解了部分 HTTP 服务压测工具,并在 windows 环境下安装和使用 go-wrk 对 bluebell 项目的 posts 接口进行了压测。

相关推荐
半壶清水5 小时前
[软考网规考点笔记]-软件开发、项目管理与知识产权核心知识与真题解析
网络·笔记·压力测试
Tony Bai6 小时前
再见,丑陋的 container/heap!Go 泛型堆 heap/v2 提案解析
开发语言·后端·golang
念何架构之路8 小时前
Go进阶之panic
开发语言·后端·golang
先跑起来再说8 小时前
Git 入门到实战:一篇搞懂安装、命令、远程仓库与 IDEA 集成
ide·git·后端·elasticsearch·golang·intellij-idea
爬山算法12 小时前
Hibernate(89)如何在压力测试中使用Hibernate?
java·压力测试·hibernate
惊讶的猫12 小时前
OpenFeign(声明式HTTP客户端)
网络·网络协议·http·微服务·openfeign
摇滚侠13 小时前
HTTP 404 - No response body available
网络·网络协议·http
Trouvaille ~13 小时前
【Linux】应用层协议设计实战(一):自定义协议与网络计算器
linux·运维·服务器·网络·c++·http·应用层协议
Tony Bai17 小时前
“Go 2,请不要发生!”:如果 Go 变成了“缝合怪”,你还会爱它吗?
开发语言·后端·golang
一晌小贪欢17 小时前
深入理解 Python HTTP 请求:从基础到高级实战指南
开发语言·网络·python·网络协议·http