Мы используем RabbitMQ для сообщений о очередности в C# .Net (клиент EasyNetQ).с использованием многопроцессорного метода EasyNetQ для одного потребителя не работает
Я хочу, чтобы одно потребительское приложение (приложение консоли C#) слушало одну очередь и предоставляло несколько обработчиков для каждого типа сообщений.
Я реализовал этот сценарий и мой код здесь:
using (var advancedBus = RabbitHutch.CreateBus("host=localhost;prefetchcount=100")
.Advanced)
{
var queue = advancedBus.QueueDeclare("MyQueue");
advancedBus.Consume(queue, x => x
.Add<MessageType1>((message, info) =>
{
Console.WriteLine("MessageType1 Body : " + message.Body.Body);
})
.Add<MessageType2>((message, info) =>
{
Console.WriteLine(" MessageType2 Body: " + message.Body.Body);
}).ThrowOnNoMatchingHandler = false);
}
Моя проблема: Но когда я исполняю этот потребитель не делает ничего. ничего не происходит.
я публиковать сообщения в этой очереди, как это:
using (var advancedBus = RabbitHutch.CreateBus("host=localhost").Advanced)
{
var queue = advancedBus.QueueDeclare("MyQueue");
if (advancedBus.IsConnected)
advancedBus.Publish(Exchange.GetDefault(), queue.Name, false, false,
new Message<MessageType1>(change));
else
result = false;
}
чем проблема.
ли 'advancedBus.IsConnected' провалится? Вы можете вообще подключиться к кролику? –
Спасибо за ваш комментарий, Да. это связано. когда я подписываюсь на конкретный тип сообщения, он отлично работает, но в моем сценарии лука это не работает. – Javad