Skip to content

Latest commit

 

History

History
73 lines (57 loc) · 1.49 KB

README.md

File metadata and controls

73 lines (57 loc) · 1.49 KB

simple_gossip

Simple implementation of gossip protocol. Infect state information around the cluster via gossipping.

Set data

ok = simple_gossip:set({<<"hello world">>, 0}).

Or

ok = simple_gossip:set(fun({Text, Counter}) -> 
                    case Counter rem 10 of 
                      0 -> 
                        no_change; 
                      Rem -> 
                        {change, {Text, Counter+(10-Rem)}} 
                    end
                end).

Retrieve data

{<<"hello world">>, 0} = simple_gossip:get().

Get cluster state.

simple_gossip:status().

Result can be

  • {ok, GossipVsn, LeaderNode, NodesInTheCluster}
  • {error, gossip_vsn_mismatch, LeaderNode, NodesInTheCluster}: Nodes do not agree on cluster state (different GossipVsn). Try again later
  • {error, {timeout, NodesDoNotResponseInTime}, LeaderNode, NodesInTheCluster}: Cannot retrieve information from cluster nodes in time

Subscribe to cluster changes

simple_gossip:subscribe(self()).

It will send a message {data_changed, {<<"hello world">>,0}} to the given process's inbox when the data has been changed.

Unsubscribe from cluster changes

simple_gossip:unsubscribe(self()).

Join node to cluster

simple_gossip:join('test@cluster').

Remove node from cluster

simple_gossip:leave('test@cluster').

Build

$ rebar3 compile

Run tests

$ rebar3 test