当前位置: 首页 > 知识库问答 >
问题:

Azure服务总线队列如何在HTTPs模式下向客户端交付消息

阎伟志
2023-03-14

我们在应用程序中对Azure服务总线队列使用HTTPs模式。

ServiceBusEnvironment.SystemConnectivity.Mode = ConnectivityMode.Https;

但我们不确定Azure服务总线如何在HTTP模式下交付消息,如果服务总线客户端使用轮询,则轮询到Azure服务总线队列的频率。

我们使用以下软件包:

Microsoft.ServiceBus;
Microsoft.ServiceBus.Messaging;

共有1个答案

楮星鹏
2023-03-14

我们似乎没有这方面的任何官方文件。然而,大多数服务总线客户机使用长轮询,这意味着他们打开到服务总线的连接,并将其保持打开状态,直到收到数据为止。如果收到消息,客户端将处理该消息并打开新连接。如果连接超时,客户机将在增量退避期后打开新连接。根据产品团队的说法,超时时间设置为30秒。

您可以使用这个测试程序来查看消息发送到队列后需要多长时间才能收到消息。它目前设置为一次运行一条消息。通过使用批处理,总吞吐量可以比本示例高得多。

在我的机器上,消息通常在放入队列后的100毫秒内被检索。如果我将睡眠时间设置为一个较大的间隔,那么检索将花费稍长的时间,因此增量后退是有效的。如果音量较低,则可能需要稍长的时间才能拾取消息。

class Program
    {
        private static readonly string connectionString = "";
        private static readonly int sleepTime = 100;
       private static readonly int messageCount = 10;
        static void Main(string[] args)
        {
            ServiceBusEnvironment.SystemConnectivity.Mode = ConnectivityMode.Https;

            var client = QueueClient.CreateFromConnectionString(connectionString, "testqueue");
            client.PrefetchCount = 1;
            var timeCheck = DateTime.UtcNow;

            client.OnMessage((message) =>
            {
                var timing = (DateTime.UtcNow - message.EnqueuedTimeUtc).TotalMilliseconds;
                Console.WriteLine($"{message.GetBody<string>()}: {timing} milliseconds between between send and receipt.");
            });

            for (int i = 0; i < messageCount; i++)
            {
                client.Send(new BrokeredMessage($"Message {i}"));
                Console.WriteLine($"Message {i} sent");
                Thread.Sleep(sleepTime);
            }

            Console.WriteLine("Test Complete");

            Console.ReadLine();
        }
    }
 类似资料:
  • 我们试图在节点应用程序中使用Azure服务总线。我们的要求是从一个队列中获取多个消息。 由于Azure SDK for Node不支持批量检索,我们决定使用AMQP。而我们可以使用这里描述的Peek消息获取消息(https://docs.microsoft.com/en-us/azure/service-bus-messaging/service-bus-amqp-request-response

  • 我有一个windows服务,它侦听Azure服务总线队列消息,以便从我的WebApi应用程序分发处理。此外,我还需要处理重复性任务(每晚/每周),我认为最好使用相同的系统来处理这些任务。 例如,假设我有一个“CleanupDb”队列,每天午夜删除过时的DB节点: 理论上这应该行得通,但我觉得我错过了一个更明显的处理方法。有没有更好的办法?

  • 使用Azure Service Bus-Topics,我想实现一个解决方案,其中一旦生产者将消息发送到Topic,消息就会被发送/通知给最终消费者(比如队列)。 我理解主题作为pub/sub模型工作,其中订阅者需要从订阅中读取消息。但是我正在寻找一种类似队列的工作方法(当接收到任何消息时,它会触发web作业/服务)。 首先,我想知道服务巴士的主题是否是正确的选择?接下来,如果可能的话,实现一个变通

  • 我们目前正在利用Azure服务总线来处理来自应用程序的各种消息。 我想知道实时处理这些消息的最佳方式是什么? 有没有一种方法可以在消息放入队列时自动执行脚本? 我只是在想,一定有比让一个单独的应用程序每分钟/30秒检查一次队列更好的方法。 谢谢各位

  • 我有一个应用程序,在这个应用程序中,我可以在进程的一部分中以JSON格式将消息写入Azure服务总线队列。我有一个下游进程,我想将该消息从队列中弹出,将json转换为一个对象,然后处理该对象。 我没有问题将消息推送到队列上,但我还没有找到任何将消息从队列中逐一或循环弹出的示例。我在微软或Github上看到的每一个例子都是一个控制台应用程序(在网络应用程序中毫无用处),它设置了某种侦听器,可以抓取队

  • 如何轮询azure服务总线以持续检查消息?下面是我从队列接收消息的方式。 我想不断地寻找信息,然后处理它。