使用单个应用程序监视多个RabbitMq订阅

时间:2015-05-29 19:33:47

标签: ruby rabbitmq amqp bunny

我有一个用.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驱动程序可以实现吗?

1 个答案:

答案 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中描述的内容。