前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >你的站点抗压么?推荐一款超方便的开源压测工具

你的站点抗压么?推荐一款超方便的开源压测工具

作者头像
HelloGitHub
发布2021-08-13 15:48:20
6720
发布2021-08-13 15:48:20
举报
文章被收录于专栏:HelloGitHub
作者:HelloGitHub-Anthony

这里是 HelloGitHub 推出的《讲解开源项目》系列,本期介绍一款标星 17.7k 纯 Go 语言实现的 HTTP(S) 压测工具——vegeta

项目地址:https://github.com/tsenart/vegeta

Vegeta 是一款用 Go 语言编写的多功能 HTTP(S) 压测工具:安装方便、功能齐全、使用简单,还可作为命令行工具或者开发库进行使用。它不仅提供了常见的压测功能,还支持格式化结果并输出为图表或动态显示当前结果。

通过本文你将掌握这款强大压测工具的基本用法,让压测只需一条命令!

一、 安装

从仓库下载编译好的二进制文件:

https://github.com/tsenart/vegeta/releases

PC 上下载 amd64 版本即可,在 Mac Os X 上使用 Homebrew 安装:

代码语言:javascript
复制
$ brew update && brew install vegeta

如果你会 Go 语言,使用 get 自动安装:

代码语言:javascript
复制
$ go get -u github.com/tsenart/vegeta

如提示找不到指令,请确保 go 以及 GOBIN 在您的环境变量中

二、快速入门

以下指令均可以在 Linux 下运行

对于下载编译好的用户建议先将 vegeta 临时添加到 PATH 路径,方便使用:

代码语言:javascript
复制
$ cd vegeta
$ export PATH=$pwd:$PATH

或者直接将 vegeta 放到 bin 目录下:

代码语言:javascript
复制
$ cd vegeta
$ sudo mv vegeta /usr/local/bin/

输入 vegeta -version 后可以显示证明安装成功。

首次使用可以使用:

代码语言:javascript
复制
$ vegeta --help

来查看支持的指令和相关例子。

1. 使用例子

在命令行输入:

代码语言:javascript
复制
$ echo "GET http://127.0.0.1:233"| vegeta attack -rate=500 -connections=1 -duration=1s | tee results.bin | vegeta report

将会得到如图所示的结果:

这条指令前半部分的 echo "GET http://127.0.0.1:233" 表示想要测试的地址,这里我使用的是 nginx 搭建的本地服务器,vegeta attack 代表测试指令,其后 -rate -connections -duration 分别表示每秒钟请求次数、每个地址最大连接数、持续时间。

攻击完成后使用 tee results.bin 保存测试报告并用 veteta report 显示报告内容。

vegeta report 也支持使用 文本、JSON、直方图、hdrplot 等:

代码语言:javascript
复制
$ echo "GET http://127.0.0.1:233"| vegeta attack -rate=500 -connections=1 -duration=5s > results.bin

文本(默认情况)

代码语言:javascript
复制
$ vegeta report results.bin

直方图

代码语言:javascript
复制
$ vegeta report -type='hist[0,1ms,2ms,3ms,4ms]' results.bin

JSON

代码语言:javascript
复制
$ vegeta report --type json results.bin

hdrplot

代码语言:javascript
复制
$ vegeta report --type hdrplot results.bin

2.生成图形

上一小节的内容,我们将文字形式的报告转为图表显示,在命令行中输入:

代码语言:javascript
复制
$ vegeta plot --title HelloGitHub results.bin > plot.html

在浏览器中打开新生成的 plot.html,即可看到图形化的测试数据:

其中 --title HelloGitHub 用来设置表头文字。此外还有

-cpu 用来设置默认使用的 cpu 核心数量,这里我默认是 12。可以使用 --threshold flag 设定下采样阈值。

vegeta plot 也可以将多个曲线放在一起,使用 vegeta plot result_1.bin result2_.bin ... result_n.bin > plot.html 即可

此外,配合 Go 下的 jaggrjplot 可以实现动态画面输出,官方给出的指令和效果如下:

代码语言:javascript
复制
$ echo 'GET http://localhost:8080' | \
    vegeta attack -rate 5000 -duration 10m | vegeta encode | \
    jaggr @count=rps \
          hist\[100,200,300,400,500\]:code \
          p25,p50,p95:latency \
          sum:bytes_in \
          sum:bytes_out | \
    jplot rps+code.hist.100+code.hist.200+code.hist.300+code.hist.400+code.hist.500 \
          latency.p95+latency.p50+latency.p25 \
          bytes_in.sum+bytes_out.sum

由于 jplot 需要 iTerm2 但笔者没有苹果系列的电脑所以关于动态输出部分的内容大家需要自己研究。

3.使用管道

如果您了解 Shell 的管道那就不难看出,前文代码中就是使用管道将 echo "GET http:// xxx" 的输出内容传给了 vegeta。通过管道,除了使用简单的 echo 工具,也可以使用其他任何程序的输出作为测试目标。

4.转换编码

vegeta 同样提供了编码转换功能,现在支持三种编码格式:Gob (二进制),CSV,以及 JSON(默认) 使用 veget encode 可以做到这几种编码的相互转换 :

代码语言:javascript
复制
$ echo "GET http://127.0.0.1:233"| vegeta attack -rate=500 -connections=1 -duration=1s > results.gob
$ cat results.gob | vegeta encode | jq .

可以显示转换为 JSON 格式的测试信息,或者:

代码语言:javascript
复制
$ cat results.gob | vegeta encode --to csv --output results.csv

输入格式的检测是自动完成的,不需要手动进行设置。

三、结语

到这里 vegeta 的基本使用到这里就结束了,它还支持一些精细参数的设置比如证书、密钥等,但限于篇幅和笔者知识水平限制无法扩展太多,大家可以根据需要的使用 vegeta [command] --help 指令进行查看,也可以阅读官方的使用手册

项目地址:https://github.com/tsenart/vegeta

温馨提示:压测虽好玩但不要贪杯哦,别压起劲儿来把线上服务给压挂了!

- END -

? 关注「HelloGitHub」第一时间收到更新?

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-07-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 HelloGitHub 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、 安装
  • 二、快速入门
    • 1. 使用例子
      • 2.生成图形
        • 3.使用管道
          • 4.转换编码
          • 三、结语
          相关产品与服务
          命令行工具
          腾讯云命令行工具 TCCLI 是管理腾讯云资源的统一工具。使用腾讯云命令行工具,您可以快速调用腾讯云 API 来管理您的腾讯云资源。此外,您还可以基于腾讯云的命令行工具来做自动化和脚本处理,以更多样的方式进行组合和重用。
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档