top | item 16512899

Ask HN: What are you using for http load testing?

74 points| marktangotango | 8 years ago | reply

I'm looking for something more flexible than apache ab, but not as heavy weight as JMeter. Ideally I'd like to be able to specify some random values in urls or post requests. My environment is linux/ubuntu. What are you using these days?

33 comments

order
[+] geocar|8 years ago|reply
I like to use wrk[1] for quick/spot testing:

* It allows me to focus on latency versus throughput independently

* It has tools for testing performance on pipelined requests (very important in my space)

* It supports scripting complex authentication processes (like magic headers and oauth2)

* It supports scripting fuzzing (random values) for URLs and POST requests

[1]: https://github.com/wg/wrk

For wide-area load testing, I simply buy some advertising since that gives me cheap access to millions of simultaneous users.

[+] anonacct37|8 years ago|reply
We use wrk since we are often load testing fairly simple services, occasionally with some Lua for cache busting. It's a great tool. Would love if it supported http2 since I work on CDN type stuff where that matters.

I love your 2nd approach (advertising). Any pointers to how to get started?

[+] togusa2017|8 years ago|reply
I agree. I also love wrk and it is pretty useful and allows scripting
[+] tpaschalis|8 years ago|reply
> not as heavy weight as JMeter

JMeter is indeed a tad heavier, but I find it's much more user friendly as in, you spend a couple of hours to build basic tests, or afternoon and have learned most of its functionality. It also has a variety of ways implementing this randomized user behavior [1].

https://tpaschalis.github.io/jmeter-random-user-actions/

[+] shifte|8 years ago|reply
You can definitely do all those things with JMeter, although the user experience is pretty naf, Gatling[3] is definitely much better at that front if you're comfortable writing Scala.

When it comes to Protocol Level Testing, those two tools are still pretty much the best bang for buck, and by far the most popular open source load generators.

If the target you're hitting is a web app and you want to create a more realistic load scenario without crafting individual requests, check out a tool called Flood Chrome, which uses thousands of instances of Google Chrome[1] to generate load. It uses the same scripting language as SeleniumJS, so it's quite easy to learn.

Also on the topic of Flood [2], they're a very good platform for abstracting away the server orchestration and results collection you'll face when you try to scale up from 1 to N servers running either Gatling or JMeter.

[1]: https://chrome.flood.io/

[2]: https://flood.io/

[3]: https://gatling.io/

[+] anonacct37|8 years ago|reply
Load testing can be hard. Wrk works for me for the most part but it's not ideal for complex flows (say e-commerce trying to simulate a real browse and checkout complete with typeahead search).

However the smarter apps can have problems too. I've pinned all available cores on fairly beefy machines because they are gunzipping bodies (behaving more like a real browser).

If you are at a scale where you need really good testing I recommend that you think of wrk results as comparable to a unit test and something like jmeter as comparable to an integration test. It's not worth the effort for most companies but where I work we serve a decent amount of traffic and downtime costs 6 figures per minute so good performance engineering and good business overlap.

[+] umen|8 years ago|reply
Jmeter is de facto in telecom , it's far from perfect but it let you define complex flows quick , the pain is that you need to ménage the test plans on the server to run all the jmx files I wish there was full web interface on the server already
[+] lyonlim|8 years ago|reply
We use JMeter and run them on AWS load generators using redline13.com
[+] hamilyon2|8 years ago|reply
One ot the best tools for load testing on ubuntu is yandex tank.