/coracle

Simulation of consensus algorithms in heterogeneous networks

Primary LanguageJavaScriptMIT LicenseMIT

Coracle coracle Clipart courtesy FCIT

Welcome to Coracle, a consensus algorithm simulator for heterogeneous networks.


Installation

An install script can be found in scripts/install.sh. The general process is as follows:

Start off by installing OPAM/OCaml, here's some helpful links:

Using OPAM we can get the project dependencies:

opam update
opam upgrade
opam install cstruct ipaddr lwt sexplib cmdline yojson

And then compile from source as follows:

git clone https://github.com/heidi-ann/coracle
cd coracle

ocaml setup.ml -configure
ocaml setup.ml -build
ocaml setup.ml -install

Now to setup the node web server:

brew install npm
npm install express serve-favicon morgan cookie-parser node-uuid debug jade serve-index moment
cd coracle/web
mkdir requests
PORT=3000 node ./bin/www

Replacing brew with your package manager of course. Setting up supervisor can allow the server to auto update when files change.

An update script can be found in scripts/update.sh.


Usage

We currently support two interfaces: command line implementation and simulation.

Implementation

Run an consensus algorithm as follows:

./coracle_unix.byte 1 --max=5

This instance will bind locally to port 5001 (5000+id) and will try to communicate with other instances at ports 5000 to 5004 (5000 to 5000+max-1).

Simulation

Ran a simulation as follows:

./coracle_sim.byte -n 5

This will ran a simualator with 5 nodes.

Bugs

Please send any comments, questions or bugs to GitHub issue tracker:

https://github.com/consensus-oracle/coracle/issues

License

This code is released under the MIT License, see the LICENSE file for full details.

Coracle clipart courtesy of FCIT for non-commercial use only


Contribute

This project is in the early development stages and we plan to have the first prototype release ready for SIGCOMM '15 on 17th Aug 2015. Contributions are welcome, these are best make via pull requests and using Github issues to mark that your working on a particular issues or features.

The current codebase is structured as follows:

Plan (19/7)

  • Simple prototype JS frontend
    • user selectes between raft and vrr, number of nodes, number of secs to simulate and main timeout parameter
    • intermediate service runs OCaml simulator process with parameters expressed in JSON
    • OCaml simulator process terminates returning simulation stats in JSON
    • stats are displayed to the user
  • Abstract over Consensus algorithms
  • Parsing simulation config in JSON
  • Terminating simulation at specified time
  • Server side parameter validation of configurations from JSON
  • Client side parameter validation of configurations from JSON
  • Advanced setting section for each protocol, hidden by default
  • Random seed field, default is randomly generated by JS but value can be changed
  • Setup coracle on demo on Azure

Plan (26/7)

This week focuses on supporting clients and VRR.

Common backend
  • Remove redundency in parsing logic between the JSON and command line interfaces
  • Adding protocol specific parameters
Raft
  • Support AppendEntries
VRR
  • Implement basic VRR (assuming access to persistent storage)
Simulation frontend (OCaml)
  • Allow random seed to be set by JSON/command line interface
Simulation frontend (JS)
  • Adding tabs (or similar) to make more space on the page e.g. seperate 'parmeters' and 'results' tabs and seperate 'general', 'raft' and 'vrr' tabs within the 'parameters page'
  • Change JSON file naming from UUID to date,time,seed
Demo & Housekeeping
  • Add web demo setup instruction to Readme
  • add web/ and other file change to file overview in Readme

Plan (2/8)

This week focuses on supporting inputting heterozygous networks and supporting clients.

Common backend
  • Support for simulated node failure
  • Adding support for client and client based events
Raft
  • Support Client Interation
VRR
Simulation frontend (OCaml)
  • Ability to store and query hetrozengous networks, later labelled with parameters like node failure rates, link direction, link latency, probability of packet loss, bandwidth etc..
  • Support for simulating clients
  • Support for basic client workload
Simulation frontend (JS)
  • Allow the user to select between a set of sample network topologies
  • Allow the user to draw static network topologies and label it
  • Basic client support
    • parameter to set number of clients
    • parameter to set regularly of client requires
Demo & Housekeeping

Plan (9/8)

This week focuses on presenting simulation results.

Common backend
Raft
VRR
Simulation frontend (OCaml)
Simulation frontend (JS)
  • Return results as graphs instead of just a table of stats
Demo & Housekeeping

Plan (16/8)

This week focuses on getting demo ready.

Common backend
  • Try using mutable event queue
Raft
  • Support for Read-only Comamnds
  • Configurable hearbeat interval and heartbeat timer
VRR
Simulation frontend (OCaml)
  • Allow simulated/random/uniform client workloads
Simulation frontend (JS)
  • Provide some specific example workloads
  • Allow the user to run multi simulations at once
Demo & Housekeeping
  • Adding Travis-CI support
  • Choose and implement a logging solution throughout code base, syslog compatible
  • add coracle to OPAM
  • add copyright/license notice to each file header
  • add ocaml 4.02.2 support (fix inconsistent interface error)
  • Register coracle domain
  • Test demo server and possiblity add use multiple machines/processes for load balancing

Ideas for future features

  • Support for other consensus protocols such as original Paxos, Zab or EPaxos
  • Dynamic membership implementation for Raft and VRR plus abiliy to test in simulation
  • MirageOS frontend
  • Complete JS implementation using js_of_ocaml
  • Support for non-ocaml consensus protocols
  • Support for simulating dynamic network topologies
  • Split this code into 3 or 4 seperate repositories
  • Unix frontend
    • Decople server id and port/host address
    • Support for config files, with a subset of logcabin's options.
    • Support for state machines as a seperate process (or even on an separate host), comms via sockets/pipes/ other IPCs
    • Proper client side executable with suuport for an application as a separate process
    • Really support for persistent storage, with write-ahead logging
    • Add a download configuration option, which provides the current configuration as a JSON file and reference to github issue tracker.
    • Add a reset button to reset feilds to original values
  • method to generate a random workload and then reuse it for other simulations
  • Allow multiple simulation configuration per run, so instead of one Raft configuration and one VRR configuration, the user can upto 5 configurations. This could be used to run