Websockets for reddit.
This service is primarily aimed at broadcasting messages to clients. It can also optionally report to the backend when clients connect or disconnect. All communication with other backend services is mediated by an AMQP broker (RabbitMQ).
Applications using this service are in charge of managing authorization. The service validates that incoming requests were authorized by the main application using a message authentication code. The path portion of a websocket request indicates which message "namespace" the socket will receive.
Messages are sent to the service via an AMQP fan out exchange. Each worker process binds to the exchange and will receive all messages sent to it. Messages are dispatched to appropriate websocket clients by mapping the message's routing key to the socket namespace specified in the websocket request.
If configured to do so, the service will also insert connect/disconnect messages onto a topic exchange in AMQP.
There are two Docker images provided for development and testing.
Dockerfile
: A Docker image definition for running a local version of the service.Dockerfile.test
: A Docker image definition for running tests.
# Exposes websocket service at 127.0.0.1:9090
docker build . -t ws-server -f Dockerfile && docker run --rm -p 9090:9090 ws-server
# Run code tests
docker build . -t ws-tests -f Dockerfile.test && docker run ws-tests
This service is used and written for reddit.com's socket needs. Client and server code examples can be found in the monolith's repos: