1

有一些关于使用 .net 框架在 webjobs v2 中使用 customQueueProcessor 为不同队列配置不同批量大小的文档。我想知道这在 webjobs v3 中是如何处理的?

       var builder = new HostBuilder()
            .UseEnvironment("Development")
            .ConfigureWebJobs(b =>
            {
                b.AddAzureStorageCoreServices();
                b.AddAzureStorage(a =>
                {
                    a.BatchSize = 1;
                });
            })

此批量大小适用于代码中的所有 QueueTrigger。如何为不同的队列使用自定义值?

4

1 回答 1

1

如果要为每个队列设置 BatchSize,可以实现 IQueueProcessorFactory:

public class CustomQueueProcessorFactory : IQueueProcessorFactory
{
    public QueueProcessor Create(QueueProcessorFactoryContext context)
    {
        if (context.Queue.Name.Equals("fooqueue"))
        {
            // demonstrates how batch processing behavior can be customized
            // per queue (as opposed to the global settings that apply to ALL queues)
            context.BatchSize = 3;
            context.NewBatchThreshold = 4;
            ...
        }

        return new QueueProcessor(context);
    }
}

在这种情况下 - 所有队列都将使用您的默认 BatchSize 配置,但队列触发器“fooqueue”会将 BatchSize 设置为 3。

在您的 ConfigureServices 方法中注册 CustomQueueProcessorFactory,如下所示:

builder.ConfigureServices((services) =>
{
    services.AddSingleton<IQueueProcessorFactory, CustomQueueProcessorFactory>();
});
于 2019-10-17T14:04:48.700 回答