首页 文章

Azure Webjobs ServiceBusTrigger - 在达到MaxDeliveryCount时执行不同的功能

提问于
浏览
4

我有几个带ServiceBus触发器的WebJobs,我有一个自定义MessageProcessor在消息处理完毕后做一些处理 .

我希望能够做一些不同的事情(具体来说,记录一个错误而不是一个警告)如果消息是在它的最后一次重试,即它即将被发送到deadletter队列 . 发送到CompleteProcessingMessageAsync函数的BrokeredMessage具有DeliveryCount,但我看不到返回原始队列以查找MaxDeliveryCount的方法 . 有任何想法吗?不同的队列具有不同的MaxDeliveryCounts,因此设置常量不是一个真正的选择 . 我能想到的唯一另一件事是为每个队列的死信队列创建一个单独的工作,但我希望能够在WebJob级别而不是每个单独的工作中完成 .

public class CustomMessageProcessor : MessageProcessor
{
    public CustomMessageProcessor(OnMessageOptions messageOptions) : base(messageOptions)
    {
    }

    public override async Task CompleteProcessingMessageAsync(BrokeredMessage message, FunctionResult result, CancellationToken cancellationToken)
    {
        if (result.Succeeded)
        {
            if (!MessageOptions.AutoComplete)
            {
                cancellationToken.ThrowIfCancellationRequested();
                await message.CompleteAsync();
            }
        }
        else
        {
            cancellationToken.ThrowIfCancellationRequested();

            //some other processing

            //If message.DeliveryCount < maxDeliveryCount 
            //  log warning
            //else
            //  log error

            await message.AbandonAsync();
        }
    }
}

2 回答

  • 1

    您应该能够从父队列中获取 Microsoft.ServiceBus.Messaging.QueueDescription ,然后使用 MaxDeliveryCount . 唯一的事情是获取队列描述是一个相对昂贵的操作,所以我建议最初做一次,并缓存每个队列的值 .

  • 0

    不同的队列具有不同的MaxDeliveryCounts,因此设置常量实际上不是一个选项

    正如Slava Asipenko提到的,我们可以为servicebus队列设置 MaxDeliveryCount .

    我如何确定消息来自哪个队列

    如果我们在发送期间设置它,我们可以获取消息属性以了解队列名称 . 以标签为例:

    var message = new BrokeredMessage(object);
    message.Label = "queue name";
    client.Send(message);
    

相关问题