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

参考文献

相关推荐
煎鱼eddycjy2 小时前
新提案:由迭代器启发的 Go 错误函数处理
go
煎鱼eddycjy2 小时前
Go 语言十五周年!权力交接、回顾与展望
go
不爱说话郭德纲19 小时前
聚焦 Go 语言框架,探索创新实践过程
go·编程语言
0x派大星2 天前
【Golang】——Gin 框架中的 API 请求处理与 JSON 数据绑定
开发语言·后端·golang·go·json·gin
IT书架2 天前
golang高频面试真题
面试·go
郝同学的测开笔记2 天前
云原生探索系列(十四):Go 语言panic、defer以及recover函数
后端·云原生·go
秋落风声3 天前
【滑动窗口入门篇】
java·算法·leetcode·go·哈希表
0x派大星5 天前
【Golang】——Gin 框架中的模板渲染详解
开发语言·后端·golang·go·gin
0x派大星5 天前
【Golang】——Gin 框架中的表单处理与数据绑定
开发语言·后端·golang·go·gin
三里清风_6 天前
如何使用Casbin设计后台权限管理系统
golang·go·casbin