After the administrator has established the relationships between them, the brokers in the event mesh dynamically discover the requirements for routing messages. As subscriptions are added and deleted, those changes are automatically advertised so that the network-wide knowledge of subscriptions is updated as changes occur. No manual intervention is required to keep subscription information current across the event mesh.
This process is somewhat different for nodes within the same cluster versus nodes in different clusters. These differences are described in the sections that follow.
Each node advertises the subscriptions it needs to its directly connected neighboring nodes. The subscription information for all the nodes' clients is aggregated and then sent to neighboring nodes. The receiving nodes don't further propagate those subscriptions. Since every node is connected to every other node, all the nodes become populated with a complete, non-duplicated set of subscription information for the entire cluster.
For example, in the above diagram, node A advertises a subscription, for instance
payments, to nodes B, C, and D. Nodes B, C, and D won't re-transmit the
payments subscription across their control channels. Note that each node may be a single broker or an HA pair/group of brokers.
Gateway nodes propagate subscription information between clusters. Before a gateway node sends that information over its external links, it first aggregates the full subscription set for its entire cluster.
For example, in the above diagram, cluster A advertises a subscription,
payments, to clusters B and C. Cluster B and Cluster C won't re-transmit the
payments subscription across their control channels. Therefore Cluster D does not receive the
Each event broker in a node persists its own Guaranteed subscriptions, but not those propagated to it by other nodes in the event mesh. When subscriptions propagate to an HA node, both brokers of that node learn of the subscriptions, regardless of which of the mates in the HA pair is currently active. Both brokers stay up-to-date with the overall network subscription set at the same time. In the case of a broker failure, that broker's HA mate continues to provide service for the local node. There is no loss of subscription state or messaging service. When the failed broker restarts, it first resynchronizes its subscription database with adjacent nodes and its own HA mate before providing service.
If a failed broker has no HA mate, or if that mate has also failed, the entire DMR node has failed and its local clients do not have service. However, Guaranteed messages that were destined to be routed to that node continue to be enqueued on its neighboring nodes, and will be delivered to clients once the failed node is restarted. There is no loss of Guaranteed messages. However, Direct messages published while the node is non-operational are lost.
As with subscription propagation, data forwarding is different within a cluster and between different clusters.
Application messages published by a client are sent over the data channels, with appropriate subscriptions, to directly connected neighboring nodes. Only one copy of a message is sent over the internal link, even if that message is destined for multiple clients. A client can publish to either a topic or queue name, and if there are multiple queues in the cluster with the same name in the same Message VPN, all of these queues receive the messages. The receiving nodes don't transmit the data any further. Since a message from a source node only traverses a single channel to get to a destination, forwarding loops never exist.
In this case, clusters send messages to other clusters directly via external links between gateways nodes. When a gateway node receives a message that originated from its own cluster, it forwards the message on its external links, only to the clusters that have a matching subscription for the message. If a gateway node receives a message that originated from a different cluster, it forwards that message on its internal links, only to the nodes in its cluster that have a matching subscription for the message. Only one copy of a message travels over an external link, even if that message is destined for multiple clients.
Clusters without a shared external link do not share messages.
DMR internal links are always used in a full mesh so that each node communicates directly with all the others. Every node in an internal DMR cluster exchanges subscriptions with every other node. Data flows only from the publisher-connected node to the consumer-connected node; messages do not flow through intermediary nodes. Client subscriptions are summarized before being shared with neighboring nodes. This means that if node A exchanges subscriptions with node B, and node A has three clients with the same subscription, only one subscription is propagated to node B on the first instance of the subscription, and is removed only after the last client removes its subscription. This minimizes the amount of subscription churn seen by the neighboring nodes. Only one copy of each event message goes across the internal link, to be fanned out on the destination node.
DMR external links are used between internally-meshed DMR clusters. There is no rule that external links must be fully-meshed, but only clusters that are directly connected via an external link can exchange messages. So, if Cluster A needs to communicate with Cluster B, then an external link must exist between the two clusters. Except in the case of a gateway node with a replication mate, there can only be one external link between any two clusters. Node subscriptions are summarized before being sent to neighboring clusters. If Cluster A has the same subscription on three nodes, only one copy of the subscription is shared across the external link to Cluster B. Only one copy of each event message goes across the external link, to be fanned out to the destination cluster's internally-linked nodes, and then further fanned out within the nodes to the subscribed clients.