|
|
1 month ago | |
|---|---|---|
| .. | ||
| README.md | 1 month ago | |
| main.go | 1 month ago | |
| peer.go | 1 month ago | |
| peer_test.go | 1 month ago | |
| state.go | 1 month ago | |
| state_test.go | 1 month ago | |
This example implements an in-memory incremental-only counter.
This is a state-based CRDT, so the write operation is incr().
Start several peers on the same host. Tell the second and subsequent peers to connect to the first one.
$ ./increment-only-counter -hwaddr 00:00:00:00:00:01 -nickname a -mesh :6001 -http :8001 &
$ ./increment-only-counter -hwaddr 00:00:00:00:00:02 -nickname b -mesh :6002 -http :8002 -peer 127.0.0.1:6001 &
$ ./increment-only-counter -hwaddr 00:00:00:00:00:03 -nickname c -mesh :6003 -http :8003 -peer 127.0.0.1:6001 &
Get current value using the HTTP API of any peer.
$ curl -Ss -XGET "http://localhost:8002/"
get => 0
Increameant the value:
$ curl -Ss -XPOST "http://localhost:8003/"
incr => 1
Get current value from another peer:
$ curl -Ss -XGET "http://localhost:8001/"
get => 1
Incremeant again:
$ curl -Ss -XPOST "http://localhost:8002/"
incr => 2
And get current value from a different peer:
> curl -Ss -XGET "http://localhost:8003/"
get => 2
GossipData.Gossiper.