我有一个Azure WebJob监听多个队列......
我可以在作业级别指定MaxDequeueCount ...
config.UseTimers();
config.Queues.BatchSize = 32;
config.Queues.MaxDequeueCount = 6;
在队列级别设置MaxDequeueCounts的最佳方法是什么?我知道我可以获得实际的出队计数并将其“手动”发送到毒药队列但我想知道这是否可以以更好的方式完成......
答案 0 :(得分:4)
如果要为不同的队列触发器功能设置不同的配置,可以实现自己的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);