Skip to content

Latest commit

 

History

History
54 lines (33 loc) · 2.75 KB

README.md

File metadata and controls

54 lines (33 loc) · 2.75 KB

P2P Publish/Subscribe Network

work in progress

current major limitations

  • not optimized for multiple topics
  • only communicates within a local area network

Install

go get -u github.com/Gaboose/go-pubsub/cmd/pubsub

Usage

Usage: pubsub [<flags>] <command> [ -help | <args> ] - p2p pubsub network

COMMANDS:
    daemon              Run a network-connected pubsub node
    pub <topic> <msg>   Publish a message
    sub <topic>         Listen for and receive messages

FLAGS:
    -apiport    int - Port of the daemon API to connect to

Use 'pubsub <command> -help' for more information about a command.

Code Structure

Every subpackage in go-pubsub/topo represents a layer of network topology and protocol. A subpackage in go-pubsub/net combines them to form a functional network and exposes functions to a daemon in go-pubsub/cmd.

Topo packages (in go-pubsub/topo) don't use the standard net library. Instead they use a ProtoNet object defined in go-pubsub/pnet/gway to serve as a gateway. ProtoNet provides Dial and Listen methods like the standard net library, but abstracts away the internet transport layer (tcp, websocket, etc.) and preselects the same "protocol" (or topology layer) on the remote node as the local one is in. This way the logic of a topology layer is guaranteed to be contained within its package and may be tested or reused as a singular unit.

Services in go-pubsub/svice also use ProtoNet for Listening and Dialing, and from the outside look and function similarly to topo packages. But services just don't deal with the actual topology of the network.

Topos

go-pubsub/topo/cyclon

Journal Article

Cyclon is an unstructured peer sampling layer. It holds a number of peer profiles. At constant time intervals it exchanges a random portion of them with one of the peers. Locally it provides other topos with a channel, which outputs profiles of uniformly random peers in the Cyclon layer.

go-pubsub/topo/broadcast

Broadcast is a flooding layer. It accepts a channel of peer profiles, connects to a small number of them and relays messages, which it hasn't seen recently. Locally it provides external packages with in and out channels to send and receive messages.

To do: