背景信息
我在RabbitMQ中有一个队列(用于电子邮件),并希望为它构建一个使用者。该队列由另一个.NET应用程序用于向客户发送电子邮件。我希望电子邮件逻辑能够位于.NET应用程序之外,并且还具有RabbitMQ提供的持久性等优点。
问题
.NET应用程序能够将电子邮件发布/推送到队列中,但我很难构建消费者!这是我的消费者代码:
// A console app that would be turned into a service via TopShelf
public void Start()
{
using (_connection = _connectionFactory.CreateConnection())
{
using (var model = _connection.CreateModel())
{
model.QueueDeclare(_queueName, true, false, false, null);
model.BasicQos(0, 1, false);
var consumer = new EventingBasicConsumer(model);
consumer.Received += (channelModel, ea) =>
{
var message = (Email) ea.Body.DeSerialize(typeof(Email));
Console.WriteLine("----- Email Processed {0} : {1}", message.To, message.Subject);
model.BasicAck(ea.DeliveryTag, false);
};
var consumerTag = model.BasicConsume(_queueName, false, consumer);
}
}
}
上面的代码应该能够从队列中获取消息并对其进行处理(根据此official guide),但这不会发生。
答案 0 :(得分:8)
问题是过早的连接处理。人们通常认为BasicConsume
是阻止呼叫,但事实并非如此。它几乎会立即返回,下一个声明是处理(关闭)频道和连接,这当然会取消您的订阅。所以要修复 - 在私有字段中存储连接和模型,并且只有在完成队列消耗时才处理它们。
答案 1 :(得分:0)
你说队列是由另一个.Net应用程序使用的,是另一个消费者吗?如果那是另一个消费者,那么请您确认您使用的是哪个交易所?如果您希望多个消费者接收消息,请继续进行“FanOut”交流