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 同一台机器就够用了。
Collection
的Request
,可以选择性的挑出合适的Request
用来做 Case,压力测试的参数有:
- Repeat: 运行整套请求的次数
- Concurrency: 并发个数
- QPS: 1 秒内限制单个节点请求的个数,默认为 0,即没有限制
- Timeout: 请求的超时时间设置,单位为秒,默认为 0,即没有超时设置
- Keeplive: 设置请求是否使用 Keeplive
运行压力测试任务时会实时显示运行状态,包括节点的状态(闪烁表示正在工作),当前任务及任务的数量,下方有三个图表,分别表示
Request
的请求消耗时间,包括 DNS, Connect, Request, Min, Max 这五个源码部署时支持改端口,之前固定用的 8080,要改需要改 js 文件,现在只需在部署文件时改就好了。
改正 Schedule 空跑时的异常。
压力测试在国庆后总算做出来,后来又花了一些时间来测试,0.2 这个版本算是告一段落。 接下来版本计划要改下,涉及新功能的都是大版本,bug 是小版本。 下个模块功能是支持 API 文档,希望能是一个自定义的,所见即所得,支持导出常用格式的 API 文档系统。 小功能和 bug 会持续改进。
Github: **https://github.com/brookshi/Hitchhiker**, 觉得不错的话麻烦 Star 支持下,谢谢。
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.