Search code examples
azureazureservicebusservicebusazure-servicebus-queues

Azure Service Bus - Multiple Topics vs Filtered Topic


I have written an implementation of azure service bus into our application using Topics which are subscribed to by a number of applications. One of the discussions in our team is whether we stick with a single Topic and filter via the properties of the message or alternatively create a Topic for our particular needs.

Our scenario is that we wish to filter by a priority and an environment variable (test and uat environments share a connection).

So do we have Topics (something like):

  • TestHigh
  • TestMedium
  • TestLow
  • UatHigh
  • UatMedium
  • UatLow

OR, just a single topic with these values set as two properties?

My preference is that we create separate topics, as we'd be utilising the functionality available and I would imagine that under high load this would scale better? I've read peeking large queues can be inefficient. It also seems cleaner to subscribe to a single topic.

Any advice would be appreciated.


Solution

  • I would go with separate topics for each environment. It's cleaner. Message counts in topics can be monitored separately for each environment. It's marginally more scalable (e.g. topic size limits won't be shared) - but the limits are generous and won't matter much in testing.

    But my main argument: that's how production will (hopefully) go. As in, production will have it's own connection (and namespace) in ASB, and will have separate topics. Thus you would not be filtering messages via properties in production, so why do it differently in testing?

    Last tip: to make topic provision easier, I'd recommend having your app auto create them on start up. It's easy to do - check if they exist, and create if they don't.