Red Hat AMQ 6
As of February 2025, Red Hat is no longer supporting Red Hat AMQ 6. If you are using AMQ 6, please upgrade: Migrating to AMQ 7.Este conteúdo não está disponível no idioma selecionado.
10.3. Topologies
10.3.1. Load-Balancing Cluster
Copiar o linkLink copiado para a área de transferência!
Overview
Copiar o linkLink copiado para a área de transferência!
					Fabric exploits the concept of broker groups to implement cluster functionality. To set up a load-balancing cluster, all of the brokers in the cluster should register with the same group name, but using unique broker names.
				
					For example, Figure 10.1, “Load-Balancing Cluster” shows a load-balancing cluster with the group name, 
loadbal, and with three brokers registered in the group: brokerx, brokery, and brokerz. This type of topology is ideal for load balancing non-persistent messages across brokers and for providing high-availability.
				Figure 10.1. Load-Balancing Cluster
Create brokers in a load-balancing cluster
Copiar o linkLink copiado para a área de transferência!
					The basic rules for creating a load-balancing cluster of brokers are as follows:
				
- Choose a group name for the load-balancing cluster.
- Each broker in the cluster registers with the chosen group.
- Each broker must be identified by a unique broker name.
- Normally, each broker is deployed in a separate container.
					For example, consider the cluster shown in Figure 10.1, “Load-Balancing Cluster”. The group name is 
loadbal and the cluster consists of three broker instances with broker names: brokerx, brokery, and brokerz.
				
					To create this cluster, perform the following steps:
				
- First of all create some containers:JBossFuse:karaf@root> container-create-child root broker 3 The following containers have been created successfully: Container: broker1. Container: broker2. Container: broker3. JBossFuse:karaf@root> container-create-child root broker 3 The following containers have been created successfully: Container: broker1. Container: broker2. Container: broker3.Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Wait until the containers are successfully provisioned. You can conveniently monitor them using thewatchcommand, as follows:JBossFuse:karaf@root> watch container-list JBossFuse:karaf@root> watch container-listCopy to Clipboard Copied! Toggle word wrap Toggle overflow 
- You can then assign broker profiles to each of the containers, using thefabric:mq-createcommand, as follows:Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
- You can use thefabric:profile-listcommand to see the new profiles created for these brokers:Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
- You can use thefabric:cluster-listcommand to view the cluster configuration for this load balancing cluster:Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
Configure clients of a load-balancing cluster
Copiar o linkLink copiado para a área de transferência!
					To connect a client to a load-balancing cluster, use a URL of the form, 
discovery:(fabric:GroupName), which automatically load balances the client across the available brokers in the cluster. For example, to connect a client to the loadbal cluster, you would use a URL like the following:
				discovery:(fabric:loadbal)
discovery:(fabric:loadbal)
					For convenience, the 
mq-create command automatically generates a profile named mq-client-GroupName, which you can combine either with the example-mq-consumer profile or with the example-mq-producer profile to create a client of the load-balancing cluster.
				
					For example, to create a consumer client of the 
loadbal group, you can deploy the mq-client-loadbal profile and the example-mq-consumer profile together in a child container, by entering the following command:
				JBossFuse:karaf@root> container-create-child --profile mq-client-loadbal --profile example-mq-consumer root consumer The following containers have been created successfully: Container: consumer.
JBossFuse:karaf@root> container-create-child --profile mq-client-loadbal --profile example-mq-consumer root consumer
The following containers have been created successfully:
	Container: consumer.
					To create a producer client of the 
loadbal group, you can deploy the mq-client-loadbal profile and the example-mq-producer profile together in a child container, by entering the following command:
				JBossFuse:karaf@root> container-create-child --profile mq-client-loadbal --profile example-mq-producer root producer The following containers have been created successfully: Container: producer.
JBossFuse:karaf@root> container-create-child --profile mq-client-loadbal --profile example-mq-producer root producer
The following containers have been created successfully:
	Container: producer.
					To verify that the clients are functioning correctly, you can connect to one of them and check the log. For example, to check the log of the consumer client:
				
JBossFuse:karaf@root> container-connect consumer JBossFuse:admin@consumer> log:display 2014-01-16 14:31:41,776 | INFO | Thread-42 | ConsumerThread | io.fabric8.mq.ConsumerThread 54 | 110 - org.jboss.amq.mq-client - 6.1.0.redhat-312 | Received test message: 982 2014-01-16 14:31:41,777 | INFO | Thread-42 | ConsumerThread | io.fabric8.mq.ConsumerThread 54 | 110 - org.jboss.amq.mq-client - 6.1.0.redhat-312 | Received test message: 983
JBossFuse:karaf@root> container-connect consumer
JBossFuse:admin@consumer> log:display
2014-01-16 14:31:41,776 | INFO  | Thread-42        | ConsumerThread                   | io.fabric8.mq.ConsumerThread   54 | 110 - org.jboss.amq.mq-client - 6.1.0.redhat-312 | Received test message: 982
2014-01-16 14:31:41,777 | INFO  | Thread-42        | ConsumerThread                   | io.fabric8.mq.ConsumerThread   54 | 110 - org.jboss.amq.mq-client - 6.1.0.redhat-312 | Received test message: 98310.3.2. Master-Slave Cluster
Copiar o linkLink copiado para a área de transferência!
Overview
Copiar o linkLink copiado para a área de transferência!
					In the master-slave pattern, multiple peer brokers provide the same service and all compete to be the master. Only one master can exist at a given time, while the rest remain on standby as slaves. If the master stops, the remaining brokers (slaves) compete to become the new master. If the broker containers are deployed across different machines or data centres, the result is a highly available broker.
				
					For example, Figure 10.2, “Master-Slave Cluster” shows a master-slave cluster with the group name, 
masterslave, and three brokers that compete with each other to register as the broker, hq-broker. A broker becomes the master by acquiring a lock (where the lock implementation is provided by the underlying ZooKeeper registry). The other two brokers that fail to acquire the lock remain as slaves (but they continue trying to acquire the lock, at regular time intervals).
				Figure 10.2. Master-Slave Cluster
Create brokers in a master-slave cluster
Copiar o linkLink copiado para a área de transferência!
					The basic rules for creating a master-slave cluster of brokers are as follows:
				
- Choose a group name for the master-slave cluster.
- Each broker in the cluster registers with the chosen group.
- Each broker must be identified by the same virtual broker name.
- Normally, each broker is deployed in a separate container.
					For example, consider the cluster shown in Figure 10.2, “Master-Slave Cluster”. The group name is 
masterslave and the cluster consists of three broker instances, each with the same broker name: hq-broker. You can create this cluster by entering a single fabric:mq-create command, as follows:
				JBossFuse:karaf@root> mq-create --create-container broker --replicas 3 --group masterslave hq-broker
JBossFuse:karaf@root> mq-create --create-container broker --replicas 3 --group masterslave hq-broker
					Alternatively, if you have already created three containers, 
broker1, broker2 and broker3 (possibly running on separate machines), you can deploy a cluster of three brokers to the containers by entering the following command:
				JBossFuse:karaf@root> mq-create --assign-container broker1,broker2,broker3 --group masterslave hq-broker
JBossFuse:karaf@root> mq-create --assign-container broker1,broker2,broker3 --group masterslave hq-broker
					The first broker that starts becomes the master, while the others are slaves. When you stop the master, one of the slaves will take over and clients will reconnect. If brokers are persistent, you need to ensure that they all use the same store—for details of how to configure this, see the section called “Configuring persistent data”.
				
Configure clients of a master-slave cluster
Copiar o linkLink copiado para a área de transferência!
					To connect a client to a master-slave cluster, use a URL of the form, 
discovery:(fabric:GroupName), which automatically connects the client to the current master server. For example, to connect a client to the masterslave cluster, you would use a URL like the following:
				discovery:(fabric:masterslave)
discovery:(fabric:masterslave)
					You can use the automatically generated client profile, 
mq-client-masterslave, to create sample clients. For example, to create an example consumer client in its own container, enter the following console command:
				JBossFuse:karaf@root> container-create-child --profile mq-client-masterslave --profile example-mq-consumer root consumer The following containers have been created successfully: Container: consumer.
JBossFuse:karaf@root> container-create-child --profile mq-client-masterslave --profile example-mq-consumer root consumer
The following containers have been created successfully:
	Container: consumer.
					And to create an example producer client in its own container, enter the following console command:
				
JBossFuse:karaf@root> container-create-child --profile mq-client-masterslave --profile example-mq-producer root producer The following containers have been created successfully: Container: producer.
JBossFuse:karaf@root> container-create-child --profile mq-client-masterslave --profile example-mq-producer root producer
The following containers have been created successfully:
	Container: producer.Locking mechanism
Copiar o linkLink copiado para a área de transferência!
					One benefit of this kind of master-slave architecture is that it does not depend on shared storage for locking, so it can be used even with non-persistent brokers. The broker group uses ZooKeeper to manage a shared distributed lock that controls ownership of the master status.
				
Re-using containers for multiple clusters
Copiar o linkLink copiado para a área de transferência!
					Fabric supports re-using the same containers for multiple master-slave clusters, which is a convenient way to economize on hardware resources. For example, given the three containers, 
broker1, broker2, and broker3, already running the hq-broker cluster, it is possible to reuse the same containers for another highly available broker cluster, web-broker. You can assign the web-broker profile to the existing containers with the following command:
				mq-create --assign-container broker1,broker2,broker3 web-broker
mq-create --assign-container broker1,broker2,broker3 web-broker
					This command assigns the new 
web-broker profile to the same containers already running hq-broker. Fabric automatically prevents two masters from running on the same container, so the master for hq-broker will run on a different container from the master for web-broker. This arrangement makes optimal use of the available resources.
				Configuring persistent data
Copiar o linkLink copiado para a área de transferência!
					When you run a master-slave configuration with persistent brokers, it is important to specify where your store is located, because you need to be able to access it from multiple hosts. To support this scenario, the 
fabric:mq-create command enables you to specify the location of the data directory, as follows:
				mq-create --assign-container broker1 --data /var/activemq/hq-broker hq-broker
mq-create --assign-container broker1 --data /var/activemq/hq-broker hq-broker
					The preceding command creates the 
hq-broker virtual broker, which uses the /var/activemq/hq-broker directory for the data (and store) location. You can then mount some shared storage to this path and share the storage amongst the brokers in the master-slave cluster.
				10.3.3. Broker Networks
Copiar o linkLink copiado para a área de transferência!
Overview
Copiar o linkLink copiado para a área de transferência!
					It is possible to combine broker clusters with broker networks, giving you a hybrid broker network that combines the benefits of broker clusters (for example, high availability) with the benefits of broker networks (managing the flow of messages between different geographical sites).
				
Broker networks
Copiar o linkLink copiado para a área de transferência!
					A broker network in JBoss A-MQ is a form of federation where brokers are linked together using network connectors. This can be used as a way of forwarding messages between different geographical locations. Messages can be forwarded either statically (where specified categories of messages are always forwarded to a specific broker), or dynamically (where messages are forwarded only in response to a client that connects to a broker and subscribes to particular queues or topics).
				
					For more details, see "Using Networks of Brokers" from the JBoss A-MQ library.
				
Creating network connectors
Copiar o linkLink copiado para a área de transferência!
					In the context of Fabric, network connectors can be created by passing the 
--network option to the fabric:mq-create command.
				Example broker network
Copiar o linkLink copiado para a área de transferência!
					Consider the scenario shown in Figure 10.3, “Broker Network with Master-Slave Clusters”.
				
Figure 10.3. Broker Network with Master-Slave Clusters
					The figure shows two master-slave clusters:
				
- The first cluster has the group name,us-west, and provides high-availability with a master-slave cluster of two brokers,us-west1andus-west2.
- The second cluster has the group name,us-east, and provides high-availability with a master-slave cluster of two brokers,us-east1andus-east2.
					Network connectors link the master brokers between each of the geographical locations (there are, in fact, two network connectors in this topology: from west to east and from east to west).
				
					To create the pair of master-slave brokers for the 
us-east group (consisting of the two containers us-east1 and us-east2), you would log on to a root container running in the US East location and enter a command like the following:
				mq-create --group us-east --network us-west --networks-username User --networks-password Pass --create-container us-east us-east
mq-create --group us-east --network us-west --networks-username User --networks-password Pass --create-container us-east us-east
					Where the 
--network option specifies the name of the broker group you want to connect to, and the User and Pass are the credentials required to log on to the us-west broker cluster. By default, the fabric:mq-create command creates a master/slave pair of brokers.
				
					And to create the pair of master-slave brokers for the 
us-west group (consisting of the two containers us-west1 and us-west2), you would log on to a root container running in the US West location and enter a command like the following:
				mq-create --group us-west --network us-east --networks-username User --networks-password Pass --create-container us-west us-west
mq-create --group us-west --network us-east --networks-username User --networks-password Pass --create-container us-west us-west
					Where 
User and Pass are the credentials required to log on to the us-east broker cluster.
				Note
						In a real scenario, you would probably first create the containers on separate machines and then assign brokers to the containers, using the 
--assign-container option in place of --create-container.
					Connecting to the example broker network
Copiar o linkLink copiado para a área de transferência!
					At the US East location, any clients that need to connect to the broker network should use the following client URL:
				
discovery:(fabric:us-east)
discovery:(fabric:us-east)
					And at the US West location, any clients that need to connect to the broker network should use the following client URL:
				
discovery:(fabric:us-west)
discovery:(fabric:us-west)
					Any messages that need to be propagated between locations, from US East to US West (or from US West to US East), are transmitted over the broker network through one of the network connectors.