Alex
Alex is one benchmark web UI using golang based on vegeta library & boom. Vegeta provides stabilized qps benchmark library. Boom provided stabilized concurrency benchmark ability.
中文文档
Alex Architecture
Alex Functionalities
- Saves benchmark parameters for repeated usage
- Saves benchmark reports for future review or sharing
- Provides simple but direct graphics & text benchmark report
- Multiple benchmarks can be running concurrently
- Multiple Host:ports can be tested as a cluster in a single benchmark with load balance supporting
- Data hotspot can be avoided by providing randomized parameters
- Provides gradually pressure with step settings
- Provides simple machine status realtime displaying while benchmark is running
Alex Limitations
- Alex is running in a single process, you should deploy multiple nodes if you need a distrubted environment.you should arrange multiple persons to operate benchmark in the same time.
- Vegeta will not stop immediately while pressure is overload.Please design your pressure steps carefully & watch your machine status carefully.
- Qps & Concurrency should not be too large.I once tested vegeta benchmark with helloword web program splitting out 1.5k bytes per request, 60000 qps reaches the limit for the network limitations of Gigabit Ethernet.
- Gzip decompression should be avoided when doing a massive pressure benchmark.Decompression costs too much cpu to make the report quite inaccurate.You can deploy multiple nodes instead.
- Report is only for suggestion, you should bravely ask yourself why.
- Http protocol only.Https is not provided.Encrypting and decrypting will cost too much cpu, report will not be accurate.
- With all of those limitations, Alex works quite well.
Installing
#install mongodb
#install golang # 1.8+ is required
go get -u github.com/golang/dep/cmd/dep # install dep
go get github.com/ireaderlab/alex # install alex
cd $GOPATH/src/github.com/ireaderlab/alex
go build
./alex
./alex -c config.json
open browser
http://localhost:8000/
Configuration
{
"BindAddr": "localhost:8000",
"MongoUrl": "mongodb://localhost:27017/alex",
"Teams": [
"python",
"java",
"php",
"go"
]
}
References
- wonderful vegeta https://github.com/tsenart/vegeta
- straight-forward boom https://github.com/rakyll/boom
Screenshots
Notice
Keep it simple, I will not add more but complex functionalities to Alex.
If there's any bugs or suggestions, please tell me, I will fix it ASAP.