Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/borud/broker

Trivial message broker
https://github.com/borud/broker

broker go golang golang-library pubsub

Last synced: 3 months ago
JSON representation

Trivial message broker

Awesome Lists containing this project

README

        

# Broker - a minimal pubsub

[![GoDoc Reference](https://godoc.org/github.com/borud/broker?status.svg)](http://godoc.org/github.com/borud/broker)

pubsub is a very small library for implementing the simplest possible
publish-subscribe mechanism for Go using channels.

## Usage

import "github.com/borud/broker"

### Creating a new broker

broker := New(Config{
DownStreamChanLen: 100,
PublishChanLen: 100,
SubscribeChanLen: 10,
UnsubscribeChanLen: 10,
DeliveryTimeout: 10*time.Millisecond,
})

The configuration options are

- `DownStreamChanLen` is the length of the channel used to send messages to the subscriber.

- `PublishChanLen` is the length of the incoming channel used by `Publish()`

- `SubscribeChanLen` is the length of the channel that accepts `Subscribe()` requests

- `UnsubscribeChanLen` is the length of the channel that accepts unsubscribe requests.

- `DeliveryTimeout` is the timeout before giving up delivering a message to a subscriber

### Subscribe to topic or topic prefix

sub, err := broker.Subscribe("/foo/bar")

### Fetch messages from subscription

for msg := range sub.Messages() {
log.Printf("topic = '%s', message = '%+v'", msg.Topic, msg.Payload)
}

### Publish message to broker with timeout

err := broker.Publish("/foo", "some payload", 300 * time.Millisecond)

### Cancel a subscription

err := sub.Cancel()

### Shut down broker

broker.Shutdown()

### Topics

Topics are entirely dynamic, meaning that a topic exists if there are
subscribers listening to it. If a message is published to a topic
that has no subscribers, nothing will happen and the message is
silently discarded.

Topics are hierarchical and look like filesyste paths and matching is
by path prefix.

/house/bedroom/light
/house/bedroom/temp
/house/kitchen/light
/house/kitchen/temp
/house/kitchen/humidity

Your subscription can be for any prefix of the path, including the
full path. You will receive all messages that match your prefix. So
for instance if you subscribe to `/house/kitchen` you will get all
messages sent to

/house/kitchen
/house/kitchen/light
/house/kitchen/temp
/house/kitchen/humidity

If you subscribe to `/house/kitchen/temp` you will only get messages
sent to this single topic since it has no children.

At this time **no** wildcard matching is supported.

## Logging

Libraries shouldn't emit log messages, but sometimes you might want to output log messages if you suspect something funny is going on. You can register your own logger via the `Config` type, like this:

b := New(Config{Logger: log.Printf})

The `Logger` is of type `Printfer` (a Printf'er to use the naming conventions of go), which looks like this:

func(string, ...interface{})

...which happens to be the signature of `log.Printf` (but not `fmt.Printf`).