基于 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 接口进行了压测。

相关推荐
言之。2 小时前
Go 语言中的 `select` 语句详解
golang
why1514 小时前
腾讯(QQ浏览器)后端开发
开发语言·后端·golang
张帅涛_6665 小时前
golang goroutine(协程)和 channel(管道) 案例解析
jvm·golang·go
一颗知足的心8 小时前
Go语言之路————指针、结构体、方法
开发语言·后端·golang
Hello.Reader10 小时前
洞悉 NGINX ngx_http_access_module基于 IP 的访问控制实战指南
tcp/ip·nginx·http
言之。11 小时前
【Go语言】ORM(对象关系映射)库
开发语言·后端·golang
席万里11 小时前
Go语言企业级项目使用dlv调试
服务器·开发语言·golang
孔令飞11 小时前
使用 Go 与 Redis Streams 构建可靠的事件驱动系统
redis·ai·云原生·golang·kubernetes
yuanlaile11 小时前
Go全栈_Golang、Gin实战、Gorm实战、Go_Socket、Redis、Elasticsearch、微服务、K8s、RabbitMQ全家桶
linux·redis·golang·k8s·rabbitmq·gin
车载测试工程师12 小时前
车载测试用例开发-如何平衡用例覆盖度和测试效率的方法论
功能测试·测试用例·压力测试·测试覆盖率·安全性测试