Skip to content

A black-box testing platform for message-based distributed algorithms.

License

Notifications You must be signed in to change notification settings

GianlucaBortoli/krafters

Repository files navigation

Krafters

A black-box testing platform for message-based distributed algorithms. This tool provides a handy way to deploy a distributed environment, execute a distributed algorithm, orchestrate a series of tests and visualize the results. The environment can be either pseudo-distributed, on localhost, or fully-distributed, on Google Compute Engine. Distributed algorithms must rely on message passing and can be of any kind, such as consensus algorithms (e.g. Raft and Paxos). Tests are performed by modifying the underlying network to introduce packet delay/loss/corruption/inversion via netem, a low-level Linux kernel tool. Their results can be visualized via plots automatically generated with seaborn.

Please refer to the project report to get further insights on the software capabilities and to read how it has been used to compare different algorithms implementations and technologies, such as RethinkDB, Multi-Paxos, Google Datastore and PySyncObj.


Information

Status: Completed

Type: Academic project

Course: Distributed algorithms

Development year(s): 2016

Authors: GianlucaBortoli (VMs configuration, plots), mfederici (test language, network manager), ShadowTemplate (GCE provisioning, test daemon)


Getting Started

The project folder contains all the Python scripts required to run the platform. Each relevant script provides a helper describing its CLI parameters.

The starting point of the platform is the provisioner, that is responsible of deploying a cluster of machines and distribute the required daemon across them. The provisioner can deploy up to 8 nodes (the default CPU quota on Google Compute Engine), either in a pseudo-distributed mode or in a fully-distributed mode. The available algorithms and technologies are RethinkDB, Multi-Paxos, Google Datastore and PySyncObj. However, new ones can be easily added.

To deploy a local cluster of 6 machines running PySyncObj, for instance, it is sufficient to execute:

$ python3 provisioner.py -n 6 -m local -a pso

Similarly, to deploy a Google Compute Engine cluster of 8 machines running RethinkDB, it is sufficient to execute:

$ python3 provisioner.py -n 8 -m gce -a rethinkdb

The provisioner will produce a JSON configuration file that can be later used to tear down the cluster. The majority of other Python/shell scripts are automatically distributed and executed on the cluster nodes.

Prerequisites

Clone the repository and install the required Python dependencies:

$ git clone https://github.com/GianlucaBortoli/krafters.git
$ cd krafters
$ pip install --user -r requirements.txt

Deployment

Make sure to set up the Google Cloud Platform project before running the provisioner. The script requires both Google Compute Engine and Google Cloud Storage.


Building tools


Contributing

This project is not actively maintained and issues or pull requests may be ignored.


License

This project is licensed under the GNU GPLv3 license. Please refer to the LICENSE.md file for details.


This README.md complies with this project template. Feel free to adopt it and reuse it.

About

A black-box testing platform for message-based distributed algorithms.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •