Listen to a Redis PubSub channel and then rebroadcast it over Server-Sent Events (SSE).
Documentation is incomplete still.
import (
"context"
"net/http"
"github.com/sfomuseum/go-pubsub/subscriber"
"github.com/whosonfirst/go-pubssed/broker"
)
ctx := context.Background()
sub, _ := subscriber.NewSubscriber(ctx, "redis://?host=localhost&port=6379&channel=pubssed")
brkr, _ := broker.NewBroker()
brkr.Start(ctx, sub)
http_handler, _ := brkr.HandlerFunc()
mux := http.NewServeMux()
mux.HandleFunc("/", http_handler)
http.ListenAndServe("localhost:8080", mux)
Note that all error handling has been removed for the sake of brevity.
import (
"log"
"github.com/whosonfirst/go-pubssed/listener"
)
callback := func(msg string) error {
log.Println(msg)
return nil
}
lstnr, _ := listener.NewListener("http://localhost:8080", callback)
lstnr.Start()
Note that all error handling has been removed for the sake of brevity.
./bin/pubssed-broadcast -h
Usage of ./bin/pubssed-broadcast:
-clients int
Number of concurrent clients (default 200)
-redis-channel string
Redis channel (default "pubssed")
-redis-host string
Redis host (default "localhost")
-redis-port int
Redis port (default 6379)
A simple command-line application for spewing as many messages (timestamps) as possible to a PubSub channel for testing how a pubssed
server will handle the load.
./bin/pubssed-client -h
Usage of ./bin/pubssed-client:
-append-root string
The destination to write log files if the 'append' callback is invoked. (default ".")
-callback string
The callback to invoke when a SSE event is received. (default "debug")
-endpoint string
The pubssed endpoint you are connecting to.
-retry-on-eof
Try to reconnect to the SSE endpoint if an EOF error is triggered. This is sometimes necessary if an SSE endpoint is configured with a too-short HTTP timeout (for example if running behind an AWS load balancer).
A simple command-line application for subscribing to an SSE server and invoke a callback when an event is received.
pubssed-client
is included as a reference implementation for the simplest-dumbest kind of "listener" application so it only has a pair of default callbacks by default.
Appends each SSE event a file named YYYY/MM/DD/YYYYMMDDHH.txt
(where datetime specifics are determined based on the time the event is received).
Logs each SSE event to STDOUT.
./bin/pubssed-server -h
Usage of ./bin/pubssed-server:
-redis-channel string
Redis channel (default "pubssed")
-redis-host string
Redis host (default "localhost")
-redis-port int
Redis port (default 6379)
-sse-endpoint string
SSE endpoint (default "/sse")
-sse-host string
SSE host (default "localhost")
-sse-port int
SSE port (default 8080)
An actuall living breathing server that will listen to (and relay) a PubSub channel and that an SSE client can connect to and receive messages.