The project provides Spring Cloud Stream Binder for Azure Service Bus Queue which allows you to build message-driven microservice using Spring Cloud Stream based on Azure Service Bus Queue service.
The Spring Cloud Stream Binder for Azure Service Bus Queue provides the binding implementation for the Spring Cloud Stream. This implementation uses Spring Integration Service Bus Queue Channel Adapters at its foundation.
This binder has no consumer group support since all consumers share one queue.
This binder has no partition support even service bus queue supports partition.
Please use this sample as a reference for how to use this binder in your projects.
Maven Coordinates
<dependency>
<groupId>com.microsoft.azure</groupId>
<artifactId>spring-cloud-azure-servicebus-queue-stream-binder</artifactId>
</dependency>
Gradle Coordinates
dependencies {
compile group: 'com.microsoft.azure', name: 'spring-cloud-azure-servicebus-queue-stream-binder'
}
The binder provides the following configuration options in application.properties
.
Name | Description | Required | Default |
---|---|---|---|
spring.cloud.azure.credential-file-path | Location of azure credential file | Yes | |
spring.cloud.azure.resource-group | Name of Azure resource group | Yes | |
spring.cloud.azure.region | Region name of the Azure resource group, e.g. westus | Yes | |
spring.cloud.azure.servicebus.namespace | Service Bus Namespace. Auto creating if missing | Yes |
It supports the following configurations with the format of spring.cloud.stream.servicebus.queue.bindings.<channelName>.producer
.
sync
Whether the producer should act in a synchronous manner with respect to writing messages into a stream. If true, the producer will wait for a response after a send operation.
Default: false
send-timeout
Effective only if sync
is set to true. The amount of time to wait for a response after a send operation, in milliseconds.
Default: 10000
It supports the following configurations with the format of spring.cloud.stream.servicebus.queue.bindings.<channelName>.consumer
.
checkpoint-mode
The mode in which checkpoints are updated.
RECORD
, checkpoints occur after each record successfully processed by user-defined message handler without any exception.
MANUAL
, checkpoints occur on demand by the user via the Checkpointer
. You can get Checkpointer
by Message.getHeaders.get(AzureHeaders.CHECKPOINTER)
callback.
Default: RECORD
prefetch-count
Prefetch count of underlying service bus client.
Default: 1
concurrency
Controls the max concurrent calls of service bus message handler and the size of fixed thread pool that handles user's business logic
Default: 1