我已经使用MassTransit实现了一个简单的发布者/消费者集合,我想让消费者从同一个队列中读取消息。但是,当我运行它时,我看到很大一部分消息被发送到错误队列而不是被消耗。从我见过的讨论(SO,Forum)来看,这应该是非常简单的RabbitMQ(只指向相同的队列),但它不起作用。是否应该设置其他配置?
这是我的发布者
public class YourMessage { public string Text { get; set; } }
public class Program
{
public static void Main()
{
Console.WriteLine("Publisher");
Bus.Initialize(sbc =>
{
sbc.UseRabbitMqRouting();
sbc.ReceiveFrom("rabbitmq://localhost/test_queue");
});
var x = Console.Read();
for (var i = 0; i <= 1000; i++)
{
Console.WriteLine("Message Number " + i);
Bus.Instance.Publish(new YourMessage { "Message Number " + i });
}
}
}
和我的消费者
public class YourMessage { public string Text { get; set; } }
public class Program
{
public static void Main()
{
Console.WriteLine("Consumer");
Bus.Initialize(sbc =>
{
sbc.UseRabbitMqRouting();
sbc.ReceiveFrom("rabbitmq://localhost/test_queue");
sbc.Subscribe(subs =>
{
var del = new Action<IConsumeContext<YourMessage>,YourMessage>((context, msg) =>
{
Console.WriteLine(msg.Text);
});
subs.Handler<YourMessage>(del);
});
});
while (true) { }
}
}
答案 0 :(得分:5)
接收者/消费者和发布者不能在同一个队列中。如果您希望竞争消费者有多个消费者实例针对同一队列运行。
我们有文档,但目前缺少此部分,所以我理解你的困惑:http://readthedocs.org/docs/masstransit/en/latest/configuration/gotchas.html#how-to-setup-a-competing-consumer如果你成功了,那么对文档的帮助就会很棒。
答案 1 :(得分:4)
因此,看起来解决方案是更改发布商中的行:
sbc.ReceiveFrom("rabbitmq://localhost/test_queue");
类似于:
sbc.ReceiveFrom("rabbitmq://localhost/test_queue_publisher");
这阻止了发布商竞争他们未配置为使用的邮件。
答案 2 :(得分:1)
刚刚在GitHub上发现了一个例子https://github.com/khalidabuhakmeh/MassTransit.ScaleOut ......