gowrk

文章目录

如何使用wrk做性能测试

##wrk的下载与安装

  • 从 github 上下载 wrk 源码
  • 切换到wrk目录
  • 使用make命令进行编译
  • 编译完成后,我们将wrk这个文件复制到bin目录下
  • 用wrk -v查看wrk的版本号来验证wrk是否安装成功

命令如下:

shell 复制代码
 git clone https://github.com/wg/wrk.git wrk
 cd wrk
 make
 cp wrk /usr/local/bin
 wrk -v
 #mac下快捷安装
 brew install wrk

wrk基本使用方法

  • 使用5个连接 2 个线程,持续运行 60 秒
lua 复制代码
wrk -c 5 -t 2 -d 60s --latency --timeout 20s -s /Users/wanjinhong/Desktop/soaringnova/demo/exam.txt https://aihubtest.digitalyili.com/aiSquare/openApi/reasoning-services/rlocrxm/sfzsbtest/idcard

lua脚本:lua脚本

参数解释:

lua 复制代码
使用方法:wrk <选项> <被测HTTP服务的url>
  Options:
    -c, --connections <N>  跟服务器建立并保持的TCP连接数量(第一个客户端是0)
    -d, --duration    <T>  压测时间,比如2s
    -t, --threads     <N>  使用多少个线程进行压测

    -s, --script      <S>  制定lua脚本路径
    -H, --header      <H>  为每一个http请求添加http头
        --latency          打印详细的延迟统计信息
        --timeout     <T>  超时时间
    -v, --version          打印正在使用的wrk的详细版本信息

  <N>代表数字参数,支持国际单位 (1k, 1M, 1G)
  <T>代表时间参数,支持国际单位  (2s, 2m, 2h)
  • 可以被描述为在60s内,6个客户端独立的分为两个线程访问我们的服务器
  • 运行结果如下:
  • 运行结果的解释:
lua 复制代码
  Thread Stats   Avg      Stdev     Max   +/- Stdev
    Latency     3.49s   814.59ms   4.82s    73.13%
    Req/Sec     1.22      2.79    10.00     88.14%

- Latency:延迟,这里可以理解为响应时间的平均值、标准差、最大值、正负一个标准差所占比,一般我们来说我们主要关注平均值和最大值. 标准差如果太大说明样本本身离散程度比较高. 有可能系统性能波动很大。

- Req/Sec:每秒请求数的平均值、标准差、最大值、正负一个标准差所占比
lua 复制代码
  Latency Distribution
     50%    3.68s
     75%    4.04s
     90%    4.40s
     99%    4.82s

- 延时分布统计:50%的请求在3.68s内完成,75%的请求在4.04s内完成,90%的请求在4.40s内完成,99%的请求在4.82s内完成。
lua 复制代码
  67 requests in 1.00m, 86.22KB read
#60s进行了67次请求,耗费86.22KB流量
lua 复制代码
Requests/sec:      1.12
#每秒处理请求数,即QPS为1.12
lua 复制代码
Transfer/sec:      1.44KB
# 平均每秒流量为1.44KB

参考文献

相关推荐
王中阳Go2 小时前
字节开源 Eino 框架上手体验:Go 语言终于有能打的 Agent 编排工具了(含 RAG 实战代码)
人工智能·后端·go
踏浪无痕5 小时前
四个指标,一种哲学:Prometheus 如何用简单模型看透复杂系统
后端·架构·go
卡尔特斯5 小时前
Go-Zero 日志使用指南
go
王中阳Go8 小时前
别再卷 Python 了!Go + 字节 Eino 框架,才是后端人转 AI 的降维打击(附源码)
后端·面试·go
踏浪无痕9 小时前
夜莺告警引擎内核:一个优雅的设计
运维·后端·go
Chasing__Dreams9 小时前
Go--2--垃圾回收
go
昵称为空C10 小时前
go+gin 入门指南
go·gin
小信啊啊1 天前
Go语言映射(Map)
golang·go
Lupino1 天前
从 Haskell 到 Go:记一次 RSA 加密协议移植与“字节陷阱”排查实录
go·haskell
Grassto2 天前
从 GOPATH 到 Go Module:Go 依赖管理机制的演进
开发语言·后端·golang·go