Dynamically provision Service Bus namespaces and entities
Azure Service Bus provides libraries to help dynamically provision Service Bus namespaces and entities. This enables complex deployments and messaging scenarios and makes it possible to programmatically determine what entities to provision.
There are two approaches you can take to manage Azure Service Bus resources programmatically. The first is to use the Azure Resource Manager-based libraries, which allow you to manage namespaces, queues, topics, subscriptions, rules, and SAS policies. Azure Resource Manager-based libraries have support for authentication through Azure Active Directory, but not through connection strings. The second approach is to leverage the same Service Bus client libraries that you use to send and receive messages. The client libraries also provide APIs to help you manage queues, topics, subscriptions, and rules in an existing namespace. They have support for authentication with connection strings. When deciding which approach to take, consider the following.
The Azure Resource Manager-based libraries offer the same functionality as Azure portal, CLI, and PowerShell when it comes to managing Service Bus namespaces and entities like queues, topics, subscriptions, etc. If you have been using Azure portal, CLI, or PowerShell for your management operations and would like a dynamic way of doing that, then these libraries might be a better choice for you.
However, if you are already using a Service Bus client library for service specific operations like send and receive messages and you need to manage Service Bus entities as well, then using the same library might be more convenient for you. The client libraries have a
ServiceBusManagementClient in the older libraries) that provides a subset of the management features provided by the Azure Resource Manager-based libraries. It must be emphasized that while the Azure Resource Manager-based libraries allow you to manage both Service Bus namespaces and entities, the client libraries only allow you to manage entities in an existing namespace but not the namespace itself.
Manage using Azure Resource Manager-based libraries
The Azure Resource Manager-based libraries allow you to manage namespaces, queues, topics, subscriptions, rules, and SAS policies. They support authentication with Azure Active Directory (Azure AD) only; they do not support connection strings.
|.NET||Azure.ResourceManager.ServiceBus||API reference for Microsoft.Azure.Management.ServiceBus||.NET|
|Java||azure-resourcemanager-servicebus||API reference for com.azure.resourcemanager.servicebus||Java|
|Python||azure-mgmt-servicebus||API reference for azure-mgmt-servicebus|
Fluent .NET and Java libraries
There is a Fluent version of the Azure Resource Manager-based libraries.
|.NET||Microsoft.Azure.Management.ServiceBus.Fluent||API reference for Microsoft.Azure.Management.ServiceBus.Fluent|
|Java||azure-resourcemanager-servicebus||API reference for com.azure.resourcemanager.servicebus.fluent|
Manage using Service Bus client libraries
Service Bus client libraries that are used for operations like send and receive messages can also be used to manage queues, topics, subscriptions, and rules in an existing Service Bus namespace. This feature is available via the
ServiceBusAdministrationClient in the latest libraries and via the
ServiceBusManagementClient in the older libraries. It is highly recommended that you use the latest libraries.
Latest Service Bus libraries
Legacy Service Bus libraries