No commit activity in last 3 years
No release in over 3 years
Codifies best practices and configuration when consuming from multiple AMQP brokers simultaneously
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

>= 0.9.6
 Project Readme

Publish One, Subscribe Many

Build Status

Table of Contents

  • Introduction
  • Testing
  • Deprecations
  • Contribute
  • Licence

This gem is a reference implementation for a Publish One, Subscribe Many pattern which is in use at SoundCloud.

The pattern assumes a single load balanced publish point and multiple direct consumption points as outlined in the follow diagram:

Publish One, Subscribe Many

In this scenario, a worker's single publish connection is load balanced to a broker. The workers have consumer connections to all possible brokers ensuring that no matter which broker a message ends up on the consumer can receive it.

Exchanges, queues, and bindings need to be declared upon connection, ensuring that all brokers will converge on the same set of routing information.

Some buzzwor{th,d}y advantages of this setup include:

  • Partitioned Load
  • Horizontal Scalability
  • High Availability (across the logical topology)

Drawbacks:

  • More complex client code
  • Another hop in the form of the load-balancer
  • A node going down, needs to be brought back up to access the messages

A common error is to conflate availability and durability. In this case, they are treated as separate concerns with the form of availability on offer refering to the ability of all connected clients to get a message from point to point under most conditions.

Durability requires messages to be published as persistent and manual intervention in the case of a node crash to bring the failed node (or disk) back into consumer awareness, to ensure the messages are flushed.

The code in this repository can be used either as a gem available on rubygems.org or as a guide to implement the above pattern using the ruby-amqp gem.

See ./examples/run for usage.

Run all the tests:

make test

Version 0.2.2:

  • Requiring this library via require 'messaging' is deprecated. Please use require 'amqp_subscribe_many' instead.

For any problems, comments or feedback please create an issue here on GitHub.

amqp-subscribe-many is released under the Mozilla Public License Version 2.0