繁体   English   中英

使用 MassTransit 在 Azure 服务总线队列上配置重复数据删除

[英]Configure Deduplication on Azure Service Bus Queue with MassTransit

我发现了以下问题( 如何为 AzureServiceBus 主题配置 RequiresDuplicateDetection )关于在 MassTransit 中从生产者应用程序配置发布主题时如何设置 RequiresDuplicationDetection 属性。 但是,对于使用Send而不是Publish传输到队列的命令,我无法找到如何执行此操作。

此外,我发现在配置有问题的队列的使用者时,我可以轻松设置该属性,如下所示。 然而,这对于我的用例来说并不理想,如果可能的话,我更希望生产者在启动和创建队列时设置这个属性。

cfg.ReceiveEndpoint(queue, e =>{
  e.RequiresDuplicateDetection = true;
  e.ConfigureConsumer<JobEventConsumer>(registrationContext, consumerConfig =>{
    consumerConfig.UseMessageRetry(r =>{
      r.Interval(10, TimeSpan.FromMilliseconds(200));
      r.Ignore<ValidationException>();
    });
  });
});

更新:经过更多调查后,我还发现在全局配置级别将属性设置为 true 似乎也不起作用。 代码如下所示

class Program {
  static async Task Main(string[] args) {
    EndpointConvention.Map<ExtractionRequest>(new Uri("queue:test-queue"));
    var busControl = Bus.Factory.CreateUsingAzureServiceBus(cfg =>{
      cfg.Host("My connection string");
      cfg.RequiresDuplicateDetection = true;
      cfg.EnablePartitioning = true;
    });

    await busControl.StartAsync();
    try {
      do {
        string value = await Task.Run(() =>{
          Console.WriteLine("Enter message (or quit to exit)");
          Console.Write("> ");
          return Console.ReadLine();
        });

        if ("quit".Equals(value, StringComparison.OrdinalIgnoreCase)) break;

        await busControl.Send<ExtractionRequest>(new {});
      }
      while (true);
    }
    finally {
      await busControl.StopAsync();
    }
  }

}

public interface ExtractionRequest {}

欢迎任何有关如何为来自生产者的队列打开 RequiresDuplicationDetection 的建议。

提前致谢,詹姆斯。

您不能从消息发送方设置队列属性,这是接收端点的责任。

接收端点是负责的组件,因为它声明了队列和相关属性。

发布不同的原因是因为主题可以由生产者配置,因为单个主题可能有多个消费者订阅。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM