Skip to content

Latest commit

 

History

History
50 lines (34 loc) · 1.62 KB

README.md

File metadata and controls

50 lines (34 loc) · 1.62 KB

Simon

Simon is a primitive distributed system that replicates data between nodes. The user decides which nodes will replicate. The user writes data to a node, and replicating nodes poll the data from that node. Each node has RPC API that has following commands:

  • read_log: reads n values from node log at index i
  • write_log: writes a batch of data to log
  • start_replicate: starts replicating from a node x
  • stop_replicate: stops replicating from whatever node it was replicating

diagram

Tests

mix test

Usage

# build binary
mix release

# run node A 
env RELEASE_DISTRIBUTION=name [email protected] SIMON_PORT=9000 _build/dev/rel/sim/bin/sim start

# read node A log, should be empty
curl http://localhost:9000/read_log?idx=0&count=5 && echo

# write an entry to node A log
curl -X PUT http://localhost:9000/write_log -H 'Content-Type: application/json' -d '{"msg":["two", "three"]}' && echo

# read node A log, should have the entries we've just added
curl http://localhost:9000/read_log?idx=0&count=5 && echo

# run node B
env RELEASE_DISTRIBUTION=name [email protected] SIMON_PORT=9001 _build/dev/rel/sim/bin/sim start

# read node B log, should be empty
curl http://localhost:9001/read_log?idx=0&count=5 && echo

# tell node B to start replicating from node A
curl -X PUT http://localhost:9001/start_replicate -H 'Content-Type: application/json' -d '{"node":"[email protected]"}' && echo

# read node B log, should have the entries of node A
curl http://localhost:9001/read_log?idx=0&count=5 && echo

# tell node B to stop replicating
curl http://localhost:9001/stop_replicate && echo