[rabbitmq-discuss] Scenario ideas
Michael Bridgen
mikeb at rabbitmq.com
Wed Aug 17 10:39:36 BST 2011
Hi Pete,
> I have been playing with rabbitmq and am thinking through some common
> scenarios I think I will need to deal with, I was wondering if anyone
> would be able to take the time to read my thoughts and validate them or
> throw a few more options in/give me some article links?
>
> I have a topic exchange and need to attach some consumers to process
> messages.
>
> If I attach a consumer with no queue name, a unique one time queue will
> be created and I can bind the exchange to this queue using a routing key
> like 'animal.mammals.#'.
Not quite; you have to create the queue with an empty name, then consume
from it using the name you get back in queue.declare_ok (and then bind
it to the exchange).
> This is great until
>
> - the consumer crashes, meaning the exchange will drop all messages (or
> they get rejected depending on the publish settings I use)
> or
Yes, that can happen. Though if the queue isn't exclusive or auto_delete
(and thereby destroyed when the connection drops or consumer goes away),
it will happily collect messages until the consumer returns. Of course,
you'd have to have recorded its name somewhere, or generated the name
yourself in a way you can repeat.
> - I need another consumer to process animals.mammals.#, which I can't do
> as I am using a one time queue and adding another will mean each message
> is delivered to 2 queues.
What is the problem with delivering to two queues? If you are using a
topic exchange, creating an anonymous, exclusive queue for each consumer
is usually appropriate.
> Are the above assumptions correct?
>
>
> So my second option is to use a named queue. I attach a consumer with a
> queue name and bind the exchange to this queue using a routing key like
> 'animal.mammals.#'.
>
> Now if I need another consumer I simply bring another one up and attach
> it to the same queue name, and they get the messages in round robin
> which is great.
It is certainly an established pattern to use a durable, named queue for
sharing out messages. Queues do double duty in AMQP -- firstly as "work
queues" of this kind, secondly as buffers for transmission.
Take care with the order in which you do things, or at least be aware
that unless you set a prefetch value, the first consumer will get all
the messages in the queue at that time.
> What's not so great is if I then decide to attach a consumer to this
> queue name (maybe by accident) and bind the exchange to a routing key
> 'animal.mammals.rabbit'
>
> Then the queue gets 2 copies of each message. Is there any way to avoid
> this other than careful management of bindings? Maybe a way of telling
> the exchange to only deliver the message once to a given queue?
No, it won't get two copies. The routing will only ever deliver any
given message once to a queue.
The combination of wildcard routing and round-robin is unusual. Would
you go into more detail about what you are trying to achieve?
--Michael
More information about the rabbitmq-discuss
mailing list