An example showing how to set up a multi-instance queue manager on Linux®. The setup is small to illustrate the concepts involved.
The example is based on Linux Red Hat Enterprise 5.
The steps differ on other UNIX platforms.
About this task
The example is set up on a 2 GHz notebook computer with 3 GB RAM running Windows 7 Service Pack 1. Two VMware virtual machines, Server1 and
Server2, run Linux Red Hat Enterprise 5 in 640 MB
images. Server1 hosts the network file system (NFS), the queue manager logs and an HA instance. It
is not usual practice for the NFS server also to host one of the queue manager instances; this is to
simplify the example. Server2 mounts Server1's queue manager logs with a standby instance. A
WebSphere® MQ MQI client is installed on an additional 400 MB
VMware image that runs Windows 7 Service Pack 1 and runs
the sample high availability applications. All the virtual machines are configured as part of a
VMware host-only network for security reasons.
Note: You should put only queue manager data on an NFS server. On the NFS, use the following three
options with the mount command to make the system secure:
-
- noexec
- By using this option, you stop binary files from being run on the NFS, which prevents a remote
user from running unwanted code on the system.
-
- nosuid
- By using this option, you prevent the use of the set-user-identifier and set-group-identifier
bits, which prevents a remote user from gaining higher privileges.
-
- nodev
- By using this option, you stop character and block special devices from being used or defined,
which prevents a remote user from getting out of a chroot jail.
Procedure
-
Log in as root.
-
Read Installing IBM® MQ - overview and follow the appropriate link to
install IBM MQ, create the mqm user and group, and define
/var/mqm.
-
Complete the task Verifying shared file system
behavior to check that the file system supports multi-instance queue managers.
-
For Server1, complete the following step:
- Create log and data directories in a common folder, /MQHA, that is to be
shared. For example:
-
mkdir
/MQHA
-
mkdir
/MQHA/logs
-
mkdir
/MQHA/qmgrs
-
For Server2, complete the following step:
- Create the folder, /MQHA, to mount the shared file system. Keep the path
the same as on Server1. For example:
-
mkdir
/MQHA
-
Ensure that the MQHA directories are owned by user and group mqm, and the
access permissions are set to
rwx
for user and group. For example
ls
-al
displays drwxrwxr-x mqm mqm 4096 Nov 27 14:38 MQDATA
.
-
chown
-R
mqm:mqm
/MQHA
-
chmod
-R
ug+rwx
/MQHA
-
Create the queue manager by entering the following command:
crtmqm
-ld
/MQHA/logs
-md
/MQHA/qmgrs
QM1
-
Add 1
/MQHA *(rw,sync,no_wdelay,fsid=0)
to /etc/exports
-
For Server1, complete the following steps:
- Start the NFS daemon:
/etc/init.d/
nfs
start
- Copy the queue manager configuration details from Server1:
dspmqinf -o command QM1
and copy the result to the clipboard:
addmqinf -s QueueManager
-v Name=QM1
-v Directory=QM1
-v Prefix=/var/mqm
-v DataPath=/MQHA/qmgrs/QM1
-
For Server2, complete the following steps:
- Mount the exported file system /MQHA by entering the following command:
mount
-t
nfs4
-o
hard,intr
Server1:/
/MQHA
- Paste the queue manager configuration command into Server2:
addmqinf -s QueueManager
-v Name=QM1
-v Directory=QM1
-v Prefix=/var/mqm
-v DataPath=/MQHA/qmgrs/QM1
-
Start the queue manager instances, in either order, with the -x parameter:
strmqm -x QM1.
The command used to start the queue manager instances must be issued from the same IBM MQ installation as the addmqinf command. To
start and stop the queue manager from a different installation, you must first set the installation
associated with the queue manager using the setmqm command. For more information,
see setmqm.