有一些关于使用 .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>();
});