开源了一个简单的http服务压测工具Alex,自带web ui,golang实现
大阳照常升起 · · 1727 次点击 · · 开始浏览Alex
Alex是基于vegeta library和boom封装的压力测试web UI。Vegeta提供稳定的qps压力源,boom提供稳定的并发数压力源。
github地址 https://github.com/ireaderlab/alex
English
Alex架构图
Alex 主要功能
保存压力测试参数以便反复压测
保存压力测试报告以便后续查看和分享
提供了简单直接的图形和文字报告
可以同时对多个http接口进行压力测试
可以同时对集群内多个host:port对进行压测
使用多组调用参数避免压测时出现的数据热点问题
使用步骤设置,生成渐进式的压力源
提供简单的压测机器系统状态实时显示功能
Alex Limitations
Alex运行在单一进程里,如果你需要分布式的压测环境,就得部署多个节点,压测时需要多人同时操作。
Vegeta在压力过载时没有提供立即停止的方法。这就需要你细心设计压测步骤,仔细观察系统状态避免系统过载。
Qps和并发数不宜过大。我曾经使用Alex工具单进程测试了HelloWorld的web程序每个请求吐出1500字节,qps最多可以达到60000,基本让千兆网卡打满。
在大型压力测试下,尽量避免Gzip解压缩。解压缩会消耗大量的cpu资源,会导致压测报告不准确。你可以通过部署多个节点来进行大型压力测试。
只支持Http协议。Https协议不打算支持,因为加密解密也同样会消耗大量cpu资源,导致报告不准确。
报告只是提供一种性能参考,要勇于对报告进行质疑。
Alex虽然有如此诸多限制,这不影响它的日常使用。
安装
install mongodb
install golang # 1.4+ is required
go get github.com/go-martini/martini
go get github.com/tsenart/vegeta
go get gopkg.in/mgo.v2
go get github.com/shirou/gopsutil
# godep restore
git clone https://github.com/shellquery/alex.git
cd alex
go build
./alex
./alex -c config.json
open browser
http://localhost:8000/
配置config.json
{
"BindAddr": "localhost:8000",
"MongoUrl": "mongodb://localhost:27017/alex",
"Teams": [
"python",
"java",
"php",
"go"
]
}
引用
棒棒的vegeta https://github.com/tsenart/vegeta
简单直接的boom https://github.com/rakyll/boom
截屏
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
Alex
Alex是基于vegeta library和boom封装的压力测试web UI。Vegeta提供稳定的qps压力源,boom提供稳定的并发数压力源。
github地址 https://github.com/ireaderlab/alex
English
Alex架构图
Alex 主要功能
保存压力测试参数以便反复压测
保存压力测试报告以便后续查看和分享
提供了简单直接的图形和文字报告
可以同时对多个http接口进行压力测试
可以同时对集群内多个host:port对进行压测
使用多组调用参数避免压测时出现的数据热点问题
使用步骤设置,生成渐进式的压力源
提供简单的压测机器系统状态实时显示功能
Alex Limitations
Alex运行在单一进程里,如果你需要分布式的压测环境,就得部署多个节点,压测时需要多人同时操作。
Vegeta在压力过载时没有提供立即停止的方法。这就需要你细心设计压测步骤,仔细观察系统状态避免系统过载。
Qps和并发数不宜过大。我曾经使用Alex工具单进程测试了HelloWorld的web程序每个请求吐出1500字节,qps最多可以达到60000,基本让千兆网卡打满。
在大型压力测试下,尽量避免Gzip解压缩。解压缩会消耗大量的cpu资源,会导致压测报告不准确。你可以通过部署多个节点来进行大型压力测试。
只支持Http协议。Https协议不打算支持,因为加密解密也同样会消耗大量cpu资源,导致报告不准确。
报告只是提供一种性能参考,要勇于对报告进行质疑。
Alex虽然有如此诸多限制,这不影响它的日常使用。
安装
install mongodb
install golang # 1.4+ is required
go get github.com/go-martini/martini
go get github.com/tsenart/vegeta
go get gopkg.in/mgo.v2
go get github.com/shirou/gopsutil
# godep restore
git clone https://github.com/shellquery/alex.git
cd alex
go build
./alex
./alex -c config.json
open browser
http://localhost:8000/
配置config.json
{
"BindAddr": "localhost:8000",
"MongoUrl": "mongodb://localhost:27017/alex",
"Teams": [
"python",
"java",
"php",
"go"
]
}
引用
棒棒的vegeta https://github.com/tsenart/vegeta
简单直接的boom https://github.com/rakyll/boom