Matthias,<br><br>Thanks, that&#39;s very helpful. A couple of follow-up questions:<br><br>1. What snapshot should I use? I tried out the default revision (not sure what that tracks) and it didn&#39;t queue like I expected; the first consumer to subscribe got all the tasks, even if more subscribers were added before the acks. I can&#39;t get the tip to run at all (crashes on startup). Presumably I need something in between?<br>
<br>2. It&#39;s not clear to me what all of the other available qos parameters mean. It appears (and again, wasn&#39;t able to try this on the tip revision) that only BasicQos(0, n, false) is supported. This sounds like it&#39;s what I want anyway (with, obv, n=1); is that right?<br>
<br>If what I have was expected to work, I can provide source code, or the crash dump if that&#39;s unexpected too.<br><br>Thanks,<br>Isaac<br><br><div class="gmail_quote">On Tue, Apr 21, 2009 at 7:38 PM, Matthias Radestock <span dir="ltr">&lt;<a href="mailto:matthias@lshift.net">matthias@lshift.net</a>&gt;</span> wrote:<br>
<blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">Isaac,<div class="im"><br>
<br>
Isaac Cambron wrote:<br>
<blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
I have a client that will publish a bunch of tasks to execute - tasks A, B, C, D, E. I have a pool of machines that, individually, know how to do some subset of the tasks. For example, let&#39;s say that machine 1 can do A, B, and C, and machine 2 can do C, D, and E. A machine can only do one task at a time, and I only want one machine to do any particular task. Tasks can wait indefinitely until there&#39;s a free machine capable of executing it.<br>

<br>
I&#39;m not sure what pieces go where. Do I create one queue per task? (If so, how will I make the machines only respond to one message from any queue at a time?)<br>
</blockquote>
<br></div>
That, in combination with a basic.qos prefetch count of 1, should work.<br>
<br>
More specifically ...<br>
<br>
- create a direct exchange to which tasks get published, using the task type as the routing key<br>
<br>
- create one queue per task type and bind it to the direct exchange with the tasks type as the binding key<br>
<br>
- let each worker machine open a channel, set the basic.qos prefetch count to 1, and then subscribe to (basic.consume) each of the queues corresponding to task types supported by that worker.<br>
<br>
- when a worker is done with a task it basic.ack&#39;s the message<br>
<br>
<br>
The prefetch count limits the number of tasks a worker will be sent before ack&#39;ing them. Note that the basic.qos functionality required to do that has not made it into an official release yet; you&#39;ll have to use  a recent snapshot of the RabbitMQ source. Your example is actually a pretty interesting use case for basic.qos, exploiting some of the more advanced aspects of that feature, so I&#39;d love to hear how it works out for you.<br>

<br>
<br>
Regards,<br><font color="#888888">
<br>
Matthias.<br>
</font></blockquote></div><br>