The documentation you are viewing is for Dapr v1.10 which is an older version of Dapr. For up-to-date documentation, see the latest version.
RabbitMQ
Component format
apiVersion: dapr.io/v1alpha1
kind: Component
metadata:
  name: rabbitmq-pubsub
spec:
  type: pubsub.rabbitmq
  version: v1
  metadata:
  - name: connectionString
    value: "amqp://localhost:5672"
  - name: protocol
    value: amqp  
  - name: hostname
    value: localhost 
  - name: username
    value: username
  - name: password
    value: password  
  - name: consumerID
    value: myapp
  - name: durable
    value: false
  - name: deletedWhenUnused
    value: false
  - name: autoAck
    value: false
  - name: deliveryMode
    value: 0
  - name: requeueInFailure
    value: false
  - name: prefetchCount
    value: 0
  - name: reconnectWait
    value: 0
  - name: concurrencyMode
    value: parallel
  - name: publisherConfirm
    value: false
  - name: enableDeadLetter # Optional enable dead Letter or not
    value: true
  - name: maxLen # Optional max message count in a queue
    value: 3000
  - name: maxLenBytes # Optional maximum length in bytes of a queue.
    value: 10485760
  - name: exchangeKind
    value: fanout
  - name: saslExternal
    value: false
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* | The RabbitMQ connection string. *Mutally exclusive with protocol, hostname, username, password field | amqp://user:pass@localhost:5672 | 
| protocol | N* | The RabbitMQ protocol. *Mutally exclusive with connectionString field | amqp | 
| hostname | N* | The RabbitMQ hostname. *Mutally exclusive with connectionString field | localhost | 
| username | N* | The RabbitMQ username. *Mutally exclusive with connectionString field | username | 
| password | N* | The RabbitMQ password. *Mutally exclusive with connectionString field | password | 
| consumerID | N | Consumer ID a.k.a consumer tag organizes one or more consumers into a group. Consumers with the same consumer ID work as one virtual consumer, i.e. a message is processed only once by one of the consumers in the group. If the consumer ID is not set, the dapr runtime will set it to the dapr application ID. | |
| durable | N | Whether or not to use durable queues. Defaults to "false" | "true","false" | 
| deletedWhenUnused | N | Whether or not the queue should be configured to auto-delete Defaults to "true" | "true","false" | 
| autoAck | N | Whether or not the queue consumer should auto-ack messages. Defaults to "false" | "true","false" | 
| deliveryMode | N | Persistence mode when publishing messages. Defaults to "0". RabbitMQ treats"2"as persistent, all other numbers as non-persistent | "0","2" | 
| requeueInFailure | N | Whether or not to requeue when sending a negative acknowledgement in case of a failure. Defaults to "false" | "true","false" | 
| prefetchCount | N | Number of messages to prefetch. Consider changing this to a non-zero value for production environments. Defaults to "0", which means that all available messages will be pre-fetched. | "2" | 
| publisherConfirm | N | If enabled, client waits for publisher confirms after publishing a message. Defaults to "false" | "true","false" | 
| reconnectWait | N | How long to wait (in seconds) before reconnecting if a connection failure occurs | "0" | 
| concurrencyMode | N | parallelis the default, and allows processing multiple messages in parallel (limited by theapp-max-concurrencyannotation, if configured). Set tosingleto disable parallel processing. In most situations there’s no reason to change this. | parallel,single | 
| enableDeadLetter | N | Enable forwarding Messages that cannot be handled to a dead-letter topic. Defaults to "false" | "true","false" | 
| maxLen | N | The maximum number of messages of a queue and its dead letter queue (if dead letter enabled). If both maxLenandmaxLenBytesare set then both will apply; whichever limit is hit first will be enforced.  Defaults to no limit. | "1000" | 
| maxLenBytes | N | Maximum length in bytes of a queue and its dead letter queue (if dead letter enabled). If both maxLenandmaxLenBytesare set then both will apply; whichever limit is hit first will be enforced.  Defaults to no limit. | "1048576" | 
| exchangeKind | N | Exchange kind of the rabbitmq exchange.  Defaults to "fanout". | "fanout","topic" | 
| saslExternal | N | With TLS, should the username be taken from an additional field (e.g. CN.) See RabbitMQ Authentication Mechanisms.  Defaults to "false". | "true","false" | 
| caCert | Required for using TLS | Input/Output | Certificate Authority (CA) certificate in PEM format for verifying server TLS certificates. | 
| clientCert | Required for using TLS | Input/Output | TLS client certificate in PEM format. Must be used with clientKey. | 
| clientKey | Required for using TLS | Input/Output | TLS client key in PEM format. Must be used with clientCert. Can besecretKeyRefto use a secret reference. | 
Communication using TLS
To configure communication using TLS, ensure that the RabbitMQ nodes have TLS enabled and provide the caCert, clientCert, clientKey metadata in the component configuration. For example:
apiVersion: dapr.io/v1alpha1
kind: Component
metadata:
  name: rabbitmq-pubsub
spec:
  type: pubsub.rabbitmq
  version: v1
  metadata:
  - name: host
    value: "amqps://localhost:5671"
  - name: consumerID
    value: myapp
  - name: durable
    value: false
  - name: deletedWhenUnused
    value: false
  - name: autoAck
    value: false
  - name: deliveryMode
    value: 0
  - name: requeueInFailure
    value: false
  - name: prefetchCount
    value: 0
  - name: reconnectWait
    value: 0
  - name: concurrencyMode
    value: parallel
  - name: publisherConfirm
    value: false
  - name: enableDeadLetter # Optional enable dead Letter or not
    value: true
  - name: maxLen # Optional max message count in a queue
    value: 3000
  - name: maxLenBytes # Optional maximum length in bytes of a queue.
    value: 10485760
  - name: exchangeKind
    value: fanout
  - name: saslExternal
    value: false
  - name: caCert
    value: ${{ myLoadedCACert }}
  - name: clientCert
    value: ${{ myLoadedClientCert }}
  - name: clientKey
    secretKeyRef:
      name: myRabbitMQClientKey
      key: myRabbitMQClientKey
Note that while the caCert and clientCert values may not be secrets, they can be referenced from a Dapr secret store as well for convenience.
Enabling message delivery retries
The RabbitMQ pub/sub component has no built-in support for retry strategies. This means that the sidecar sends a message to the service only once. When the service returns a result, the message will be marked as consumed regardless of whether it was processed correctly or not. Note that this is common among all Dapr PubSub components and not just RabbitMQ.
Dapr can try redelivering a message a second time, when autoAck is set to false and requeueInFailure is set to true.
To make Dapr use more sophisticated retry policies, you can apply a retry resiliency policy to the RabbitMQ pub/sub component.
There is a crucial difference between the two ways to retry messages:
- When using autoAck = falseandrequeueInFailure = true, RabbitMQ is the one responsible for re-delivering messages and any subscriber can get the redelivered message. If you have more than one instance of your consumer, then it’s possible that another consumer will get it. This is usually the better approach because if there’s a transient failure, it’s more likely that a different worker will be in a better position to successfully process the message.
- Using Resiliency makes the same Dapr sidecar retry redelivering the messages. So it will be the same Dapr sidecar and the same app receiving the same message.
Create a RabbitMQ server
You can run a RabbitMQ server locally using Docker:
docker run -d --hostname my-rabbit --name some-rabbit rabbitmq:3
You can then interact with the server using the client port: localhost:5672.
The easiest way to install RabbitMQ on Kubernetes is by using the Helm chart:
helm install rabbitmq stable/rabbitmq
Look at the chart output and get the username and password.
This will install RabbitMQ into the default namespace. To interact with RabbitMQ, find the service with: kubectl get svc rabbitmq.
For example, if installing using the example above, the RabbitMQ server client address would be:
rabbitmq.default.svc.cluster.local:5672
Use topic exchange to route messages
Setting exchangeKind to "topic" uses the topic exchanges, which are commonly used for the multicast routing of messages.
Messages with a routing key will be routed to one or many queues based on the routing key defined in the metadata when subscribing.
The routing key is defined by the routingKey metadata. For example, if an app is configured with a routing key keyA:
apiVersion: dapr.io/v1alpha1
kind: Subscription
metadata:
  name: order_pub_sub
spec:
  topic: B
  route: /B
  pubsubname: pubsub
  metadata:
    routingKey: keyA
It will receive messages with routing key keyA, and messages with other routing keys are not received.
// publish messages with routing key `keyA`, and these will be received by the above example.
client.PublishEvent(context.Background(), "pubsub", "B", []byte("this is a message"), dapr.PublishEventWithMetadata(map[string]string{"routingKey": "keyA"}))
// publish messages with routing key `keyB`, and these will not be received by the above example.
client.PublishEvent(context.Background(), "pubsub", "B", []byte("this is another message"), dapr.PublishEventWithMetadata(map[string]string{"routingKey": "keyB"}))
Bind multiple routingKey
Multiple routing keys can be separated by commas.
The example below binds three routingKey: keyA, keyB, and "". Note the binding method of empty keys.
apiVersion: dapr.io/v1alpha1
kind: Subscription
metadata:
  name: order_pub_sub
spec:
  topic: B
  route: /B
  pubsubname: pubsub
  metadata:
    routingKey: keyA,keyB,
For more information see rabbitmq exchanges.
Related links
- Basic schema for a Dapr component in the Related links section
- Read this guide for instructions on configuring pub/sub components
- Pub/Sub building block
Feedback
Was this page helpful?
Glad to hear it! Please tell us how we can improve.
Sorry to hear that. Please tell us how we can improve.