Federation Reference
Overview
This guides provides a reference on all the fields that can be set when defining various parameters related to federation.
Please refer to other federation-related guides to learn about the concepts and how to get started.
Configuration Reference
Policies
A policy can apply an upstream set (including the implicitly-defined upstream set named "all") or a single upstream to a set of exchanges and/or queues.
To apply all upstreams:
rabbitmqctl set_policy federate-me '^federated\.' '{"federation-upstream-set":"all"}'
To apply a named set of upstreams:
rabbitmqctl set_parameter federation-upstream-set location-1 '[{"upstream": "up-1"}, {"upstream": "up-2"}]'
rabbitmqctl set_policy federate-me '^federated\.' '{"federation-upstream-set":"location-1"}'
To apply a single upstream:
rabbitmqctl set_policy federate-me '^federated\.' '{"federation-upstream":"up-1"}'
Note that you cannot use the federation-upstream
and federation-upstream-set keys together in a
policy. For more detail on policies, see the policy documentation.
Upstreams
A federation-upstream parameter specifies how
to connect to a remote node or cluster as well as certain properties
of a link (connection). Upstreams are defined using the
rabbitmqctl set_parameter federation-upstream command which accepts
an upstream name and an upstream definition JSON object:
rabbitmqctl set_parameter federation-upstream <i>name</i> '<i>json-object</i>'
The upstream definition object can contain the following keys:
Applicable to Both Federated Exchanges and Queues
| Parameter Name | Description | 
| uri | The AMQP URI(s) for the upstream. See the query parameter reference for the underlying client library extensions (including those for TLS) which are available to federation. The value can either be a string, or a list of strings. If more than one string is provided, the federation plugin will randomly pick one URI from the list when attempting to connect. This can be used to connect to an upstream cluster and ensure the link will eventually find another node in the event that one fails. All URIs are assumed to be pointed at nodes in a single cluster. To connect to multiple endpoints in separate clusters simultaneously use multiple upstreams. | 
| prefetch-count | The maximum number of deliveries pending acknowledgement on a link at
any given time. Default is  | 
| reconnect-delay | The duration (in seconds) to wait before reconnecting to the broker after being disconnected. Default is 1. | 
| ack-mode | Determines how the link should acknowledge messages. If set
to  If set to  If set to  | 
| trust-user-id | Determines how federation should interact with
the validated user-id feature.
If set to  | 
Applying to Federated Exchanges Only
The following upstream parameters are only applicable to federated exchanges.
| Parameter Name | Description | 
| exchange | The name of the upstream exchange. Default is to use the same name as the federated exchange. | 
| max-hops | The maximum number of federation links that a message
published to a federated exchange can traverse before it
is discarded. Default is 1. Note that even if
 | 
| queue-type | The queue type of the internal upstream queue used by exchange federation. Defaults to  Changing the queue type will delete and recreate the upstream queue by default.
This may lead to messages getting lost or not routed anywhere during the re-declaration.
To avoid that, set  Available since:  | 
| resource-cleanup-mode | Whether to delete the internal upstream queue when federation links stop. By default, the internal upstream queue is deleted immediately when a federation link stops.
Set to  | 
| expires | The expiry time (in milliseconds) after which
an upstream queue for
a federated exchange may be deleted if a connection to the upstream is lost.
The default is  This setting controls how long the upstream queue will last before it is eligible for deletion if the connection is lost. This value controls TTL settings for the upstream queue. | 
| message-ttl | The expiry time for messages in the upstream queue
for a federated exchange (see  This value controls TTL settings for the messages in the upstream queue. | 
Applicable to Federated Queues Only
| Parameter Name | Description | 
| queue | The name of the upstream queue. Default is to use the same name as the federated queue. | 
| consumer-tag | The consumer tag to use when consuming from upstream. Optional. | 
Upstream Sets
Each upstream-set is a set of upstreams. It can be more convenient to use a set
and refer to it in a federation policy definition that repeatedly listing upstreams.
# up-1 and up-2 are previously declared upstreams
rabbitmqctl set_parameter federation-upstream-set location-1 '[{"upstream": "up-1"}, {"upstream": "up-2"}]'
Supported keys of the JSON objects are
| Parameter Name | Description | 
| upstream | The name of an upstream. Mandatory. | 
In addition, any of the properties from an upstream can be overridden in an upstream set.
There is an implicitly-defined upstream set, all,
which contains all upstreams created in the target virtual host.
cluster name
The federation plugin uses the cluster name defined within the server to identify itself to other nodes in the federation graph. The default is constructed from the RabbitMQ node name and the fully-qualified domain name of the first node to form the cluster.
This can be changed with the
rabbitmqctl set_cluster_name
command or via the management UI.
It is important to specify this explicitly if your DNS will not give machines distinct names.
Here's an Example:
rabbitmqctl set_cluster_name "east1-production"