API 测试工具 Hitchhiker 0.6 发布,改进压力测试 - 开源中国社区
Float_left Icon_close
API 测试工具 Hitchhiker 0.6 发布,改进压力测试
不白兄 2017年12月19日

API 测试工具 Hitchhiker 0.6 发布,改进压力测试

不白兄 不白兄 发布于2017年12月19日 收藏 51

阿里云高性能云服务器,2折起! >>> >>>  

Hitchhiker 是一款开源的支持多人协作的 Restful Api 测试工具,支持Schedule, 数据对比,压力测试,支持上传脚本定制请求,可以轻松部署到本地,和你的team成员一起协作测试Api。

详细介绍请看: http://doc.hitchhiker-api.com/cn/introduction.html

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

更新内容:

1. 重写压力测试

Hitchhiker 之前的压力测试节点是一个基于Go的 [Hitchhiker-Node](https://github.com/brookshi/Hitchhiker-Node),早期阶段Hitchhiker的脚本功能并不复杂,不支持上传js库,async/await,以及文件读取保存等,而Go的高并发非常有吸引力,做了下调研后,使用otto做为js解释器,是可以满足那时的脚本运行逻辑的,所以选用了Go做压力测试的节点,在早期是够用的。

后来Hitchhiker开始支持更多复杂的脚本功能,比如自定义js库,因为npm里的很多js库都基于Nodejs,而目前的Go以及otto满足不了这种需求,除非再加一个Node进程来执行脚本,然而这样又过于复杂,还不如直接使用Nodejs来写,所以综合考虑后还是使用Nodejs重写了压力测试点。

重写之后的压力测试是集成在Server一起的,也就是不用再部署其他的程序,而且支持现有所有的脚本功能。

两种方法的优劣:

Go的高并发以及goroutine使得写起这种压力程序时非常之轻松,性能也很有保障,缺点还是在于Hitchhiker的脚本是js,所以Go执行这些脚本比较费劲,也因此目前基于Go的压力点不支持Hitchiker脚本的高级特性。

Nodejs写这种压力测试程序就比较费劲,需要自己管理多进程,以及进程间通信,还没法精确控制1秒的请求数,也就是压力测试的参数QPS对Nodejs的压力点是没用的,不过好在Hitchhiker Server也是基于Nodejs的,所以可以重用请求处理的逻辑,而且Api的压力测试本质上是高IO的,所以Nodejs的性能也很不错。不过Nodejs的程序目前还不支持分布式,稍后会加上去,主体功能已经完成。

稍微比较了下两者的性能,在单机上基本旗鼓相当。

目前是以基于Nodejs的版本为默认的,也可以选用Go的,不过Go的暂时会停止维护,除非Go有了基于Node的js解释器,那时再考虑移回来。

2. 重新整理请求流程

之前的请求流程有点乱,导致有些问题不容易发现,比如环境变量没应用到Test脚本里,所以在改这个bug时重构了下代码,把流程理清下:

3. 修正Bug

1. global function 里的内容在切换模块后会消失
2. schedule里的请求返回是图片时,会造成JSON.parse失败,导致异常,改了图片只保存链接,不保存内容
3. 浏览器里压力测试的websocket有时会失败,加了重试
4. schedule的定时跑的记录会有1分钟左右的误差
5. 改请求的method时name会被重置
6. response 展示图片

4. 后续计划

短期内还是以增加测试新功能为主,比如curl生成请求,请求生成代码等,长期的一个是文档,一个是Mock,开始根据需求来决定下一个模块。

Github: https://github.com/brookshi/Hitchhiker
码云: https://gitee.com/iwxiaot/Hitchhiker

本站文章除注明转载外,均为本站原创或编译。欢迎任何形式的转载,但请务必注明出处,尊重他人劳动共创开源社区。
转载请注明:文章转载自 开源中国社区 [http://www.oschina.net]
本文标题:API 测试工具 Hitchhiker 0.6 发布,改进压力测试
分享
评论(9)
精彩评论
1

引用来自“二灯大师”的评论

能不能导出并发日志?

引用来自“不白兄”的评论

日志都在logs目录下,不知道你具体要哪些日志,现在的压力测试的日志不是太详细,因为量大的话详细的日志会很快占用大量空间,以后会加个参数来控制

引用来自“二灯大师”的评论

比如接口的并发等

引用来自“不白兄”的评论

比如每秒并发有多少,tps,已完成了多少之类的吗,这个信息倒是有,不过没保存下来,也就是在运行过程中在图上表现了一下,需要的话记到日志里没什么问题
这个应该有, 比如我批量导入一系列的接口信息, 点击测试, 然后导出测试报表或者日志之类的
最新评论
0

引用来自“二灯大师”的评论

能不能导出并发日志?

引用来自“不白兄”的评论

日志都在logs目录下,不知道你具体要哪些日志,现在的压力测试的日志不是太详细,因为量大的话详细的日志会很快占用大量空间,以后会加个参数来控制

引用来自“二灯大师”的评论

比如接口的并发等

引用来自“不白兄”的评论

比如每秒并发有多少,tps,已完成了多少之类的吗,这个信息倒是有,不过没保存下来,也就是在运行过程中在图上表现了一下,需要的话记到日志里没什么问题

引用来自“二灯大师”的评论

这个应该有, 比如我批量导入一系列的接口信息, 点击测试, 然后导出测试报表或者日志之类的
有道理,加到计划中,导到excel应该是比较好的选择
1

引用来自“二灯大师”的评论

能不能导出并发日志?

引用来自“不白兄”的评论

日志都在logs目录下,不知道你具体要哪些日志,现在的压力测试的日志不是太详细,因为量大的话详细的日志会很快占用大量空间,以后会加个参数来控制

引用来自“二灯大师”的评论

比如接口的并发等

引用来自“不白兄”的评论

比如每秒并发有多少,tps,已完成了多少之类的吗,这个信息倒是有,不过没保存下来,也就是在运行过程中在图上表现了一下,需要的话记到日志里没什么问题
这个应该有, 比如我批量导入一系列的接口信息, 点击测试, 然后导出测试报表或者日志之类的
0

引用来自“二灯大师”的评论

能不能导出并发日志?

引用来自“不白兄”的评论

日志都在logs目录下,不知道你具体要哪些日志,现在的压力测试的日志不是太详细,因为量大的话详细的日志会很快占用大量空间,以后会加个参数来控制

引用来自“二灯大师”的评论

比如接口的并发等
比如每秒并发有多少,tps,已完成了多少之类的吗,这个信息倒是有,不过没保存下来,也就是在运行过程中在图上表现了一下,需要的话记到日志里没什么问题
0

引用来自“二灯大师”的评论

能不能导出并发日志?

引用来自“不白兄”的评论

日志都在logs目录下,不知道你具体要哪些日志,现在的压力测试的日志不是太详细,因为量大的话详细的日志会很快占用大量空间,以后会加个参数来控制
比如接口的并发等
0

引用来自“二灯大师”的评论

能不能导出并发日志?
日志都在logs目录下,不知道你具体要哪些日志,现在的压力测试的日志不是太详细,因为量大的话详细的日志会很快占用大量空间,以后会加个参数来控制
0
能不能导出并发日志?
0
有压力测试这个还可以
0

引用来自“long_ai_xin”的评论

装不到本地, 心好累
有哪方面的问题欢迎在github上或者群里提出来
0
装不到本地, 心好累
顶部