开源 API 集成测试工具 Hitchhiker v0.2 更新 - 压力测试

2017-10-16 07:33:59 +08:00
 brookshi

Hitchhiker 是一款开源的 Restful Api 集成测试工具,支持 Schedule, 数据对比,压力测试,可以轻松部署到本地,和你的 team 成员一起管理 Api。

详细介绍请看: http://www.cnblogs.com/brookshi/p/7440663.html

在线体验: http://www.hitchhiker-api.com/, 可以用 try without login 来免登录使用 (在线演示不支持压力测试,虚拟机单核的,撑不住)。

这次发布的算是一个大版本,主要增加一个重磅功能 - 压力测试:

压力测试

双 11 快到了,经常会有整点秒杀的活动,秒杀就是一个典型的压力场景,所以建了一个简单的 Case 来表现这种场景,来展示 Hitchhiker 压力测试功能:

Hitchhiker 使用一个基于 Golang 的分布式压力节点,这是一个单独的项目:Hitchhiker-Node。得益于 Golang 的交叉编译,轻松跨平台生成文件,所以只有一个可执行文件和一个配置文件,没有环境依赖,直接执行。

使用时在release 页面先选择对应平台的 zip 文件下载下来,解压后会有两个文件,一个可执行文件和一个配置文件 config.json,打开配置文件,把Address的值从 localhost 改为部署 Hitchhiker 机器的 ip,然后再执行 Hitchhiker-Node 文件,这样就弄好了一个压力点。

如果想压出很大的请求就可以考虑部署到多台机器上,Hitchhiker 会自动根据机器的 CPU 核数来分配任务,当然,一般情况下直接部署到 Hitchhiker 同一台机器就够用了。

压力测试用的也是CollectionRequest,可以选择性的挑出合适的Request用来做 Case,压力测试的参数有:

  • Repeat: 运行整套请求的次数
  • Concurrency: 并发个数
  • QPS: 1 秒内限制单个节点请求的个数,默认为 0,即没有限制
  • Timeout: 请求的超时时间设置,单位为秒,默认为 0,即没有超时设置
  • Keeplive: 设置请求是否使用 Keeplive

运行压力测试任务时会实时显示运行状态,包括节点的状态(闪烁表示正在工作),当前任务及任务的数量,下方有三个图表,分别表示

  1. 当前的运行进度,包括完成的数量及 TPS
  2. 各个Request的请求消耗时间,包括 DNS, Connect, Request, Min, Max 这五个
  3. 请求失败的状态,包括 No Response, Server Error(500), Test 失败 这三种情况

其他改动

  1. 源码部署时支持改端口,之前固定用的 8080,要改需要改 js 文件,现在只需在部署文件时改就好了。

  2. 改正 Schedule 空跑时的异常。

后续计划

压力测试在国庆后总算做出来,后来又花了一些时间来测试,0.2 这个版本算是告一段落。 接下来版本计划要改下,涉及新功能的都是大版本,bug 是小版本。 下个模块功能是支持 API 文档,希望能是一个自定义的,所见即所得,支持导出常用格式的 API 文档系统。 小功能和 bug 会持续改进。

Github: **https://github.com/brookshi/Hitchhiker**, 觉得不错的话麻烦 Star 支持下,谢谢。

4599 次点击
所在节点    程序员
21 条回复
brookshi
2017-10-17 12:45:26 +08:00
@andyangyu
看起来是数据库没连上,sudo docker ps 看看数据库的容器是否运行起来,有运行的话用 sudo docker exec -it hitchhiker bash 来进到容器里执行 pm2 restart index 试试

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/397891

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX