如何在队列级别设置 MaxDequeueCount

How to set the MaxDequeueCount at the Queue Level

我有一个 Azure WebJob 监听多个队列...

我可以在作业级别指定 MaxDequeueCount...

    config.UseTimers();
    config.Queues.BatchSize = 32;
    config.Queues.MaxDequeueCount = 6;

在队列级别设置 MaxDequeueCounts 的最佳方法是什么?我知道我可以获得实际的出队计数并将其发送到有毒队列 "manually" 但我想知道是否可以用更好的方式完成此操作...

如果你想为不同的队列触发函数设置不同的配置,你可以实现自己的QueueProcessorFactory,并根据队列名称重新设置上下文的一些配置。

public class MyQueueProcessorFactory : IQueueProcessorFactory
{
    public  QueueProcessor Create(QueueProcessorFactoryContext context)
    {
        if (context == null)
        {
            throw new ArgumentNullException("context");
        }
        if (context.Queue.Name == "queue1")
        {
            context.MaxDequeueCount = 2;
        }
        else if (context.Queue.Name == "queue2")
        {
            context.MaxDequeueCount = 4;
        }
        return new QueueProcessor(context);
    }
}

要使用自定义 QueueProcessorFactory,我们需要按如下方式设置 QueueProcessorFactory 属性。

JobHostConfiguration config = new JobHostConfiguration();
config.Queues.QueueProcessorFactory = new MyQueueProcessorFactory();
JobHost host = new JobHost(config);