我有一个用.NET编写的应用程序,可以使用单个使用者监视多个RabbitMq队列。
例如:
using (IConnection connection = factory.CreateConnection())
{
using (IModel channel = connection.CreateModel())
{
var _consumer = new QueueingBasicConsumer(channel);
string[] list = new string[] { "Queue1", "Queue2", "Queue3", "Queue4" };
_consumer = new QueueingBasicConsumer(channel);
foreach (string currQueueName in list)
{
channel.QueueDeclare(currQueueName, false, false, false, null);
channel.BasicConsume(currQueueName, true, _consumer);
}
while (true)
{
var ea = (BasicDeliverEventArgs)_consumer.Queue.Dequeue();
var body = ea.Body;
var message = Encoding.UTF8.GetString(body);
Console.WriteLine(" [x] Received {0}", message);
ProcessMessage(message);
}
}
}
基本上,我只是希望能够跨多个队列分配工作,但只有一个应用程序可以全部使用它们(或者可以部署多个应用程序并执行相同的功能)。
我正试图在队列中分散工作,以便消费者在队列中平等地工作。
使用Bunny或本机Ruby驱动程序可以实现吗?
答案 0 :(得分:0)
我想我只需要花更多时间在这上面。
我正在添加一个简短的答案,以防这有助于其他人(或者如果有人想提供更清洁的解决方案:P)
client = Bunny.new
client.start
channel = client.create_channel
queues = %w(testing1 testing2 testing3)
queues.each do |name|
channel.queue(name).subscribe(timeout: 2) do |info, props, body|
puts "[#{name}] Got #{body}"
end
end
loop do
sleep 1
end
这有效地完成了我在OP中描述的内容。