Requirements for RDQM DR solution
You must meet a number of requirements before you configure an RDQM disaster recovery (DR) queue manager pair.
System requirements
Before you configure RDQM DR, you must complete some configuration on each of the servers that
are to host RDQM DR queue managers.
- Each node requires a volume group named
drbdpool
. The storage for each disaster recovery replicated data queue manager (DR RDQM) is allocated as two separate logical volumes per queue manager from this volume group. (Each queue manager requires two logical volumes to support the reverting to snapshot operation, so each DR RDQM is allocated just over twice the storage that you specify when you create it.) For the best performance, this volume group should be made up of one or more physical volumes that correspond to internal disk drives (preferably SSDs). - After you have created the
drbdpool
volume group, do nothing else with it. IBM® MQ manages the logical volumes created indrbdpool
, and how and where they are mounted. - Each node requires an interface that is used for the data replication. This should have
sufficient bandwidth to support the replication requirements given the expected workload of all of
the replicated data queue managers.
For maximum fault tolerance, this interface should be an independent Network Interface Cards (NICs).
- DRBD requires that each node used for RDQM has a valid internet host name (the value that is
returned by
uname -n
), as defined by RFC 952 amended by RFC 1123. - If there is a firewall between the nodes used for DR RDQM, then the firewall must allow traffic
between the nodes on the ports that are used for replication. A sample script is provided,
/opt/mqm/samp/rdqm/firewalld/configure.sh, that opens up the necessary ports if
you are running the standard firewall in RHEL. You must run the script as
root
. If you are using some other firewall, examine the service definitions/usr/lib/firewalld/services/rdqm*
to see which ports need to be opened. The script adds the following permanent firewallD service rules for DRBD and IBM MQ (you can edit the script to omit the Pacemaker ports if you are not using HA):- MQ_INSTALLATION_PATH/samp/rdqm/firewalld/services/rdqm-drbd.xml allows TCP ports 7000-7100.
- MQ_INSTALLATION_PATH/samp/rdqm/firewalld/services/rdqm-mq.xml allows TCP port 1414 (you must edit the script if you require a different port)
- If the system uses SELinux in a mode other than permissive, you must run the following
command:
semanage permissive -a drbd_t
Network requirements
It is recommended that you locate the nodes used for disaster recovery in different data centers.
You should be aware of the following limitations:
- Performance degrades rapidly with increasing latency between data centers. IBM will support a latency of up to 5 ms for synchronous replication and 100 ms for asynchronous replication.
- The data sent across the replication link is not subject to any additional encryption beyond that which might be in place from using IBM MQ AMS.
- Configuring an RDQM queue manager for disaster recovery incurs an overhead due to the requirement to replicate data between the two RDQM nodes. Synchronous replication incurs a greater overhead than asynchronous replication. When synchronous replication is used, disk I/O operations are blocked until the data is written to both nodes. When asynchronous replication is used, data must only be written to the primary node before processing can continue.
User requirements for working with queue managers
To create, delete, or configure replicated data queue managers (RDQMs) you must either be the
root user, or have a user ID belonging to the
mqm
group that is granted sudo
authority for the following commands:- crtmqm
- dltmqm
- rdqmdr
A user who belongs to the
mqm
group can view the state and status of a DR RDQM
by using the following commands:- dspmq
- rdqmstatus
The mqm
user must have the same UID on both servers, and the
mqm
group must have the same GID on both servers.