Skip to content

Latest commit

 

History

History
85 lines (68 loc) · 2.58 KB

README.md

File metadata and controls

85 lines (68 loc) · 2.58 KB

Noria Lobsters benchmark

This benchmark uses trawler to generate a workload that is similar to that of the lobste.rs news aggregator. It is the same benchmark that was used in §8.1 in the OSDI'18 Noria paper.

The benchmark issues SQL queries from the Lobsters code base according to the production traffic patterns reported here. It can run in one of three modes:

  • mysql: the exact SQL queries issued by Lobsters.
  • noria: the original Lobsters queries with minor tweaks to make them work with Noria.
  • natural: queries without manual pre-computations.

The Noria benchmarks should all be run through the MySQL adapter.

Compile the benchmark with

$ cargo b --release --bin lobsters

Then start the backend you want to benchmark, you must first decide what target load (reqscale) you want to test. The reqscale is a scaling factor relative to that seen by the production Lobsters deployment. See the paper linked above for good values to try.

Then, run, for example, with Noria's natural queries:

$ target/release/lobsters \
   --warmup 0 \
   --runtime 0 \
   --issuers 24 \
   --queries natural \
   --prime \
   "mysql://lobsters:[email protected]/lobsters"
$ target/release/lobsters \
   --reqscale 3000 \
   --warmup 120 \
   --runtime 0 \
   --issuers 24 \
   --queries natural \
   "mysql://lobsters:[email protected]/lobsters"
$ target/release/lobsters \
   --reqscale <target> \
   --warmup 20 \
   --runtime 30 \
   --issuers 24 \
   --queries natural \
   "mysql://lobsters:[email protected]/lobsters"

The first command primes the backend with initial users, stories, and comments. The second warms up the database. The last issues requests at the given target rate for 50 seconds (discarding the first 20s) and reports the observed latencies for the different Lobsters pages.

To run a different reqscale, you only need to run the last command.

Running the Noria backend

Make sure ZooKeeper is running on the server machine. Then use the following command to run noria-server:

$ cargo r --release --bin noria-server -- \
   --deployment x --durability memory --no-reuse \
   --address <srv-ip> --shards 0 -v

And this to run the MySQL adapter on the clients:

$ cargo r --release -- \
   --deployment x --no-sanitize --no-static-responses \
   -z <srv-ip>:2181 -p 3306 -v

Where srv-ip is the server's external IP address.