|
9 年之前 | |
---|---|---|
.. | ||
scripts | 9 年之前 | |
src | 9 年之前 | |
.gitignore | 9 年之前 | |
Readme.md | 9 年之前 | |
benchmark_config.json | 9 年之前 | |
pom.xml | 9 年之前 | |
setup.sh | 9 年之前 | |
source_code | 9 年之前 |
This is the Vert.x Web portion of a benchmarking test suite comparing a variety of web development platforms.
http://localhost:8080/plaintext
http://localhost:8080/mongo/db http://localhost:8080/mongo/queries?queries=5
http://localhost:8080/jdbc/db http://localhost:8080/jdbc/queries?queries=5
http://localhost:8080/mongo/update?queries=5
http://localhost:8080/jdbc/update?queries=5
http://localhost:8080/mongo/fortunes
http://localhost:8080/jdbc/fortunes
It's best to generate load from a completely separate machine from the server if you can, to avoid resource contention during the test.
We use the wrk load generation tool to generate the load for our benchmark runs. It's the best tool we've found for the job and supports HTTP pipelining (used by the plaintext scenario) via its scripting interface. Wrk will only run from a Linux machine however, so if you must use Windows, try using ab (Apache Bench).
You'll need to clone the wrk repo on your load generation machine and follow their instructions to build it.
Here's a sample wrk command to generate load for the JSON scenario. This run is using 256 connections across 32 client threads for a duration of 10 seconds.
wrk -c 256 -t 32 -d 10 http://127.0.0.1:8080/json
To generate pipelined load for the plaintext scenario, use the following command, assuming your CWD is the root of this
repo and wrk is on your path. The final argument after the --
is the desired pipeline depth. We always run the
plaintext scenario at a pipeline depth of 16, just like the Techempower Benchmarks.
wrk -c 256 -t 32 -d 15 -s ./scripts/pipeline.lua http://localhost:8080/psql/update?queries=20 -- 16
Note you may want to tweak the number of client threads (the -t
arg) being used based on the specs of your load
generation machine.