Skip to content

Rolis: a software approach to efficiently replicating multi-core transactions; eurosys2022

License

Notifications You must be signed in to change notification settings

metalicjames/rolis-eurosys2022

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

25 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Welcome to the Rolis artifact for our Eurosys'22 submission.

Rolis: a software approach to efficiently replicating multi-core transactions

Project organization

  • benchmarks
    • benchmarks/sto: Transaction control, serialization (in Transactions.cc) and replay interface implementation (in ReplayDB.cc)
    • benchmarks/tpcc.cc: TPC-C benchmark implementation
    • benchmarks/micro_bench.cc: YCSB++ benchmark implementation
  • docker: the docker container
  • scripts: several experimental scripts and scripts to plot figures in the paper
  • third-party: the dependencies on MultiPaxos ported from Janus with the leader election
  • dbtest.cc: the main() portal to start the program, including replay logic

You can find a more detailed document in modules.

Run the experiment locally

In this section, you can set up Rolis locally for testing and verification, which is mainly for badges Artifacts Available and Artifacts Evaluated - Functional.

Obtain a Docker container

We run all our codes on ubuntu 18.04 which mainly depends on several Linux libraries (i.e., boost, gcc and libyaml-cpp-dev). We provide a docker image with all required dependencies and source code for ease so you can run on any local machine supporting Docker. You can directly build a runnable Rolis instance with all required dependencies and source code via

cd ~
git clone https://github.com/shenweihai1/rolis-eurosys2022.git
cd ~/rolis-eurosys2022
cd ./docker
bash docker.sh

Minimal working examples locally

You can start Rolis instance locally (using different processes to mimic actual distributed environment) to verify the functionability of the program through three minimal experiments:

  • two running replicas without failure;
  • Silo only;
  • three replicas with failure;
# 1. enter the docker container
docker exec -it ubuntu_eurosys2022 /bin/bash

# 2. run 3 minimal experiments (inside the container): 
make paxos
cd ./test && bash ./runner.sh

We should observe status "PASS" in green at the end of experiments as below alter

Run the expriment in actual distributed environment

Before moving on, please make distributed environment ready in environment.

We provide one-click runnable to generate all results under folder ./results. It would take up to 2 ~ 3 hours to run all experiments.

# on the leader replica
cd ~/rolis-eurosys2022
bash one-click.sh

case 1: run chosen experiments

The one-click script usually can complete all experiments till the end, but everything can happen. In this case, you don't have to re-run completed experiments. You can comment the completed experiments and run the incompleted ones in the one-click.sh. For example, you can choose to run experiment-8 as below alt

case 2: run the experiment with chosen worker threads

For example, in the following experiment-4, numbers for worker threads 13-15 are missing. You can re-run the experiment with chosen worker threads by configuration in the one-click.sh. alt

alt

You can find a more detailed experiment instructions in experiments.

The results should be as below alt

  1. batch-latency.log: the 50th, 90th and 95th latency results of Rolis with different batch-sizes
  2. batch-throughput.log: the throughput results of Rolis with different batch-sizes
  3. failover-16-throughput.log: the throughput over time in the failover scenario
  4. scalability-tpcc.log: the throughput of Rolis with different worker threads under tpcc workload
  5. scalability-ycsb.log: the throughput of Rolis with different worker threaders under ycsb++ workload
  6. silo-only-tpcc.log: the throughput of Silo under tpcc workload
  7. silo-only-ycsb.log: the throughput of Silo under ycsb++ workload

About

Rolis: a software approach to efficiently replicating multi-core transactions; eurosys2022

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 72.5%
  • Python 17.1%
  • C 4.9%
  • TeX 2.1%
  • Shell 1.7%
  • M4 1.1%
  • Other 0.6%