Azure Service Bus Queues
Detailed documentation on the Azure Service Bus Queues pubsub component
Component format
To set up Azure Service Bus Queues pub/sub, create a component of type pubsub.azure.servicebus.queues
. See the pub/sub broker component file to learn how ConsumerID is automatically generated. Read the How-to: Publish and Subscribe guide on how to create and apply a pub/sub configuration.
This component uses queues on Azure Service Bus; see the official documentation for the differences between topics and queues. For using topics, see the Azure Service Bus Topics pubsub component.
Connection String Authentication
apiVersion: dapr.io/v1alpha1
kind: Component
metadata:
name: servicebus-pubsub
spec:
type: pubsub.azure.servicebus.queues
version: v1
metadata:
# Required when not using Microsoft Entra ID Authentication
- name: connectionString
value: "Endpoint=sb://{ServiceBusNamespace}.servicebus.windows.net/;SharedAccessKeyName={PolicyName};SharedAccessKey={Key};EntityPath={ServiceBus}"
# - name: consumerID # Optional
# value: channel1
# - name: timeoutInSec # Optional
# value: 60
# - name: handlerTimeoutInSec # Optional
# value: 60
# - name: disableEntityManagement # Optional
# value: "false"
# - name: maxDeliveryCount # Optional
# value: 3
# - name: lockDurationInSec # Optional
# value: 60
# - name: lockRenewalInSec # Optional
# value: 20
# - name: maxActiveMessages # Optional
# value: 10000
# - name: maxConcurrentHandlers # Optional
# value: 10
# - name: defaultMessageTimeToLiveInSec # Optional
# value: 10
# - name: autoDeleteOnIdleInSec # Optional
# value: 3600
# - name: minConnectionRecoveryInSec # Optional
# value: 2
# - name: maxConnectionRecoveryInSec # Optional
# value: 300
# - name: maxRetriableErrorsPerSec # Optional
# value: 10
# - name: publishMaxRetries # Optional
# value: 5
# - name: publishInitialRetryIntervalInMs # Optional
# value: 500
Warning
The above example uses secrets as plain strings. It is recommended to use a secret store for the secrets as described here.
Spec metadata fields
Field | Required | Details | Example |
---|---|---|---|
connectionString | Y | Shared access policy connection string for the Service Bus. Required unless using Microsoft Entra ID authentication. | See example above |
consumerID | N | Consumer ID (consumer tag) organizes one or more consumers into a group. Consumers with the same consumer ID work as one virtual consumer; for example, a message is processed only once by one of the consumers in the group. If the consumerID is not provided, the Dapr runtime set it to the Dapr application ID (appID ) value. | Can be set to string value (such as “channel1” in the example above) or string format value (such as “{podName}” , etc.). See all of template tags you can use in your component metadata. |
namespaceName | N | Parameter to set the address of the Service Bus namespace, as a fully-qualified domain name. Required if using Microsoft Entra ID authentication. | “namespace.servicebus.windows.net” |
timeoutInSec | N | Timeout for sending messages and for management operations. Default: 60 | 30 |
handlerTimeoutInSec | N | Timeout for invoking the app’s handler. Default: 60 | 30 |
lockRenewalInSec | N | Defines the frequency at which buffered message locks will be renewed. Default: 20 . | 20 |
maxActiveMessages | N | Defines the maximum number of messages to be processing or in the buffer at once. This should be at least as big as the maximum concurrent handlers. Default: 1000 | 2000 |
maxConcurrentHandlers | N | Defines the maximum number of concurrent message handlers. Default: 0 (unlimited) | 10 |
disableEntityManagement | N | When set to true, queues and subscriptions do not get created automatically. Default: “false” | “true” , “false” |
defaultMessageTimeToLiveInSec | N | Default message time to live, in seconds. Used during subscription creation only. | 10 |
autoDeleteOnIdleInSec | N | Time in seconds to wait before auto deleting idle subscriptions. Used during subscription creation only. Must be 300s or greater. Default: 0 (disabled) | 3600 |
maxDeliveryCount | N | Defines the number of attempts the server will make to deliver a message. Used during subscription creation only. Default set by server. | 10 |
lockDurationInSec | N | Defines the length in seconds that a message will be locked for before expiring. Used during subscription creation only. Default set by server. | 30 |
minConnectionRecoveryInSec | N | Minimum interval (in seconds) to wait before attempting to reconnect to Azure Service Bus in case of a connection failure. Default: 2 | 5 |
maxConnectionRecoveryInSec | N | Maximum interval (in seconds) to wait before attempting to reconnect to Azure Service Bus in case of a connection failure. After each attempt, the component waits a random number of seconds, increasing every time, between the minimum and the maximum. Default: 300 (5 minutes) | 600 |
maxRetriableErrorsPerSec | N | Maximum number of retriable errors that are processed per second. If a message fails to be processed with a retriable error, the component adds a delay before it starts processing another message, to avoid immediately re-processing messages that have failed. Default: 10 | 10 |
publishMaxRetries | N | The max number of retries for when Azure Service Bus responds with “too busy” in order to throttle messages. Defaults: 5 | 5 |
publishInitialRetryIntervalInMs | N | Time in milliseconds for the initial exponential backoff when Azure Service Bus throttle messages. Defaults: 500 | 500 |
Microsoft Entra ID authentication
The Azure Service Bus Queues pubsub component supports authentication using all Microsoft Entra ID mechanisms, including Managed Identities. For further information and the relevant component metadata fields to provide depending on the choice of Microsoft Entra ID authentication mechanism, see the docs for authenticating to Azure.
Example Configuration
apiVersion: dapr.io/v1alpha1
kind: Component
metadata:
name: servicebus-pubsub
spec:
type: pubsub.azure.servicebus.queues
version: v1
metadata:
- name: namespaceName
# Required when using Azure Authentication.
# Must be a fully-qualified domain name
value: "servicebusnamespace.servicebus.windows.net"
- name: azureTenantId
value: "***"
- name: azureClientId
value: "***"
- name: azureClientSecret
value: "***"
Message metadata
Azure Service Bus messages extend the Dapr message format with additional contextual metadata. Some metadata fields are set by Azure Service Bus itself (read-only) and others can be set by the client when publishing a message.
Sending a message with metadata
To set Azure Service Bus metadata when sending a message, set the query parameters on the HTTP request or the gRPC metadata as documented here.
metadata.MessageId
metadata.CorrelationId
metadata.SessionId
metadata.Label
metadata.ReplyTo
metadata.PartitionKey
metadata.To
metadata.ContentType
metadata.ScheduledEnqueueTimeUtc
metadata.ReplyToSessionId
Note
- The
metadata.MessageId
property does not set theid
property of the cloud event returned by Dapr and should be treated in isolation. - The
metadata.ScheduledEnqueueTimeUtc
property supports the RFC1123 and RFC3339 timestamp formats.
Receiving a message with metadata
When Dapr calls your application, it attaches Azure Service Bus message metadata to the request using either HTTP headers or gRPC metadata. In addition to the settable metadata listed above, you can also access the following read-only message metadata.
metadata.DeliveryCount
metadata.LockedUntilUtc
metadata.LockToken
metadata.EnqueuedTimeUtc
metadata.SequenceNumber
To find out more details on the purpose of any of these metadata properties refer to the official Azure Service Bus documentation.
In addition, all entries of ApplicationProperties
from the original Azure Service Bus message are appended as metadata.<application property's name>
.
Note
All times are populated by the server and are not adjusted for clock skews.
Sending and receiving multiple messages
Azure Service Bus supports sending and receiving multiple messages in a single operation using the bulk pub/sub API.
Configuring bulk publish
To set the metadata for bulk publish operation, set the query parameters on the HTTP request or the gRPC metadata as documented here
Metadata | Default |
---|---|
metadata.maxBulkPubBytes | 131072 (128 KiB) |
Configuring bulk subscribe
When subscribing to a topic, you can configure bulkSubscribe
options. Refer to Subscribing messages in bulk for more details. Learn more about the bulk subscribe API.
Configuration | Default |
---|---|
maxMessagesCount | 100 |
Create an Azure Service Bus broker for queues
Follow the instructions here on setting up Azure Service Bus Queues.
Note
Your queue must have the same name as the topic you are publishing to with Dapr. For example, if you are publishing to the pub/sub "myPubsub"
on the topic "orders"
, your queue must be named "orders"
. If you are using a shared access policy to connect to the queue, that policy must be able to “manage” the queue. To work with a dead-letter queue, the policy must live on the Service Bus Namespace that contains both the main queue and the dead-letter queue.
Retry policy and dead-letter queues
By default, an Azure Service Bus Queue has a dead-letter queue. The messages are retried the amount given for maxDeliveryCount
. The default maxDeliveryCount
value defaults to 10, but can be set up to 2000. These retries happen very rapidly and the message is put in the dead-letter queue if no success is returned.
Dapr Pub/sub offers its own dead-letter queue concept that lets you control the retry policy and subscribe to the dead-letter queue through Dapr.
- Set up a separate queue as that dead-letter queue in the Azure Service Bus namespace, and a resilience policy that defines how to retry.
- Subscribe to the topic to get the failed messages and deal with them.
For example, setting up a dead-letter queue orders-dlq
in the subscription and a resiliency policy lets you subscribe to the topic orders-dlq
to handle failed messages.
For more details on setting up dead-letter queues, see the dead-letter article.
Related links
- Basic schema for a Dapr component
- Pub/Sub building block
- Read this guide for instructions on configuring pub/sub components
Last modified October 11, 2024: Fixed typo (#4389) (fe17926)