azure - 如何防止在 WebJob 处理时重复消息不插入到服务总线队列中?

标签 azure message-queue azureservicebus azure-servicebus-queues brokeredmessage

我想确保如果队列中已存在相同的消息,则在 webjob 处理第一条消息时应忽略第二条消息(不插入到队列中)。

我尝试了以下代码:

 var namespaceManager =
                NamespaceManager.CreateFromConnectionString(connectionString);

            if (!namespaceManager.QueueExists(queueName))
            {
                namespaceManager.CreateQueue(new QueueDescription(queueName) { RequiresDuplicateDetection = true });
            }

属性RequiresDuplicateDetection应确保重复消息。

 // Get messageFactory for runtime operation
            MessagingFactory messagingFactory = MessagingFactory.CreateFromConnectionString(connectionString);

            QueueClient queueClient = messagingFactory.CreateQueueClient("TestQueue");

            BrokeredMessage message = new BrokeredMessage();
            message.MessageId = "Localization";
            queueClient.Send(message);

但是 webjob 会为每个 messageId 获取触发器。我给了 sleep 时间 150000 毫秒,但在此之前我尝试将相同的消息插入到相同的队列中,但由于重复的消息,不应插入该队列。

我试过MSDN但它在 Azure Webjob 中不起作用。

WebJob 代码:

public static void ProcessQueueMessage([ServiceBusTrigger("TestQueue")] BrokeredMessage message, TextWriter log)
        {
 log.WriteLine("Webjob Start" + message.MessageId + DateTime.Now);
            Thread.Sleep(150000);
            log.WriteLine("Webjob End" + message.MessageId + DateTime.Now);
        }

最佳答案

重复消息检测基于 BrokeredMessageMessageId。 Azure 产品团队有一个示例说明此功能 here .

关于azure - 如何防止在 WebJob 处理时重复消息不插入到服务总线队列中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28690002/

相关文章:

c# - Azure AD 通过补丁调用更改密码

database - 消息系统中针对表的队列

spring-boot - Spring boot - 如何使用故障转移 URL 连接到外部 ActiveMQ 主/从集群

message-queue - 消息困惑: Pub/Sub vs Multicast vs Fan Out

c# - Windows Azure MessageLockLostException

windows - Azure 网站授予访问权限

Azure 无法从 terraform 中的角色获取 UUID

git - 无法再 git Push 到 Azure

azure - 如何使我的 Azure 逻辑应用程序可移植

azureservicebus - 在 Azure 服务总线中处理不同消息类型的好做法是什么