How to accomplish FIFO with Azure service bus topics

后端 未结 2 864
粉色の甜心
粉色の甜心 2020-12-20 22:11

Have been looking for a Message bus with publish/subscribe functionality. Found that AWS SQS does not support FIFO, so had to give up on it. Working with Azure Service bus,

相关标签:
2条回答
  • 2020-12-20 22:34

    You can use session to get an Azure topic to provide FIFO ordering but that's not quite the same thing as guaranteeing the order in which messages are processed.

    Sessions are not enough of a guarantee here. For example, if you are using PeekLock mode then a message that times out will return to the queue and be processed out of order. You can use ReceiveAndDelete mode to counter this behavior but that means you lose the transactional nature of message handling.

    One of the reasons why documentation may be a little light on this area is that it isn't a common use case. Messaging is about decoupling though asynchronous communication and ordering guarantees create temporal coupling between applications.

    Ideally you should design your payloads so ordering doesn't matter. If that fails, use a timestamp that allows you to discard messages received out of order.

    Discussed in more detail here: Don’t assume message ordering in Azure Service Bus

    0 讨论(0)
  • 2020-12-20 22:35

    You should be able to achieve this by setting property SupportOrdering to true

        // Configure Topic Settings
        TopicDescription td = new TopicDescription("TestTopic");
        td.SupportOrdering = true;
    
        // Create a new Topic with custom settings
        string connectionString = CloudConfigurationManager.GetSetting("Microsoft.ServiceBus.ConnectionString");
    
        var namespaceManager = NamespaceManager.CreateFromConnectionString(connectionString);
        namespaceManager.CreateTopic(td);
    
    0 讨论(0)
提交回复
热议问题