如何为"webjobs v3"中的不同队列配置不同的批量大小?



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

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

此批大小适用于代码中的所有队列触发器。如何对不同的队列使用自定义值?

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

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>();
});

相关内容

  • 没有找到相关文章

最新更新