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

参考文献

相关推荐
风飘百里4 小时前
分组加密核心原理与实践解析(AES/SM4)
go
岁忧4 小时前
(LeetCode 每日一题) 1865. 找出和为指定值的下标对 (哈希表)
java·c++·算法·leetcode·go·散列表
Wo3Shi4七7 小时前
哈希冲突
数据结构·算法·go
Code季风8 小时前
GORM 部分关键字详解与关联查询实战:Preload 与 Association 的使用对比
go·orm
Code季风8 小时前
深入理解 gRPC 服务定义:从基础到高级
rpc·go
Code季风8 小时前
深入学习 gRPC 流式通信:四种模式详解与实战代码解析
go·grpc
程序员爱钓鱼9 小时前
Go语言泛型-泛型约束与实践
前端·后端·go
程序员爱钓鱼9 小时前
Go语言泛型-泛型对代码结构的优化
后端·google·go
DemonAvenger9 小时前
TCP连接池设计与实现:提升Go应用网络性能
网络协议·架构·go