Windows服务总线 - 多个接收器

时间:2013-03-06 02:45:12

标签: c# service servicebus

我正在使用我在本地计算机上安装的Windows Service Bus(非Azure)。我按照这里的示例进行了操作,但换了我的本地实例:http://www.windowsazure.com/en-us/develop/net/how-to-guides/service-bus-queues/

我现在有两个控制台应用程序设置,一个是接收器,另一个是发送器。接收器只是侦听新消息并执行输出的console.writeline:

// Continuously process messages sent to the "TestQueue" 
            while (true)
            {
                BrokeredMessage message = Client.Receive();

                if (message != null)
                {
                    try
                    {
                        Console.WriteLine("Body: " + message.GetBody<string>());
                        Console.WriteLine("MessageID: " + message.MessageId);
                        Console.WriteLine("Test Property: " +
                           message.Properties["TestProperty"]);
                        Console.WriteLine("----------------------");

                        // Remove message from queue
                        message.Complete();
                    }
                    catch (Exception)
                    {
                        // Indicate a problem, unlock message in queue
                        message.Abandon();
                    }
                }
            } 

接下来我有发件人:

 while (true)
            {

                // Create message, passing a string message for the body
                BrokeredMessage message = new BrokeredMessage("Test message " + i);

                // Set some addtional custom app-specific properties
                message.Properties["TestProperty"] = "TestValue";
                message.Properties["Message number"] = i;

                // Send message to the queue
                Client.Send(message);

                i++;

                System.Threading.Thread.Sleep(50);
            }

这实际上都很有效。我可以启动1个接收器,发送者和我可以看到消息。然后我启动第二个接收器,消息自动在两个接收器之间来回传递。

然而,当我启动第三个接收器时,第一个接收器退出获取消息(直到另一个接收器退出)。

有没有办法让所有三个(或“n”)接收器处理来自队列的消息?我想可能在队列设置中会有一个设置,但我似乎无法找到。

1 个答案:

答案 0 :(得分:1)

如果您减少发件人的睡眠状态,第一个接收者是否开始检索邮件?可能是您的队列被过度读取,使得第二个和第三个接收器碰巧检索消息,但第一个接收器无法检索消息,因为队列是空的。

您的目标是让独立读者处理队列,还是您在一对多通信之后,每个接收者都有机会处理消息?如果是这样,那么您应该使用Topics and Subscriptions