Verifying the installation of MQ Telemetry using the command line
Follow these instructions to run scripts and a sample application to verify that the MQ Telemetry components have installed, and are able to publish and subscribe.
Before you begin
The telemetry (MQXR) service must be started to run the sample programs. The user ID must be a member of the mqm group.
The SampleMQM script creates and uses a queue manager called MQXR_SAMPLE_QM. Therefore, do not run unaltered on a system that already has a MQXR_SAMPLE_QM queue manager. Any changes made might have implications for the configuration of the existing queue manager.
This task uses the mqttv3app sample Java application, and the associated Java client library. These resources are no longer included in MQ Telemetry, they are now part of the MA9C: IBM® Messaging Telemetry Clients SupportPac. You install this SupportPac as part of this task. If we have a recent copy of this SupportPac, you might also need to compile the sample application.
There are two commands to run the mqttv3app sample Java application. The first command creates a subscription, then waits for a message. The second command publishes to that subscription. Therefore the commands must be entered into different command lines or shell windows.
To perform verification on a server or device without a GUI, scripts are provided in the samples directory. The SampleMQM script performs the required steps to configure MQ Telemetry. The mqttv3app sample Java application can then be run to validate the basic or custom MQ Telemetry configuration by connecting, subscribing to topics, and publishing messages. The CleanupMQM sample script can be run to delete the queue manager created by the SampleMQM script.
The following items summarize the main goals that can be achieved using this verification procedure:
- Validate a basic or custom MQ Telemetry configuration by connecting, subscribing to topics and publishing messages.
- Showcase the main features of the MQTT protocol.
- Provide a simple tool to aid in debugging MQ Telemetry applications.
Procedure
- Download the MA9C: IBM Messaging Telemetry Clients SupportPac.
-
Decompress the client pack into a directory of your own choosing.
This task uses the mqttv3app sample Java application, and the associated mqttv3 Java client library. If we have an older version of the MA9C SupportPac, the sample applications and client libraries are in the CLIENTPACKDIR/SDK/clients/java directory, where CLIENTPACKDIR is the directory in which you decompressed the client pack.
Note: Recent versions of the MA9C: IBM Messaging Telemetry Clients SupportPac do not have the /SDK/ directory, and do not include a compiled copy of the mqttv3app sample application. If we have a recent version of the MA9C SupportPac, you need to compile the application manually, then create the /SDK/ directory and contents. For the latest information about available clients and samples, see IBM MQ Telemetry Transport sample programs. -
Configure MQ Telemetry.
The SampleMQM script runs through a series of steps, including creating the MQXR_SAMPLE_QM queue manager, defining and starting the telemetry (MQXR) service, setting up the default transmission queue, and configuring a telemetry channel.
For information about performing this manually, see Configure a queue manager for telemetry on Linux and AIX , or Configure a queue manager for telemetry on Windows .- On Windows systems, enter the following command in a
command line:
MQINSTDIR\mqxr\samples\SampleMQM.bat
- On AIX or Linux systems, enter the following command in a shell window:
MQINSTDIR/mqxr/samples/SampleMQM.sh
- On Windows systems, enter the following command in a
command line:
-
Run the mqttv3app sample Java application to create a subscription.
- On Windows systems, enter the following commands in
a command line:
java -cp "CLIENTPACKDIR\SDK\clients\java\org.eclipse.paho.sample.mqttv3app.jar; CLIENTPACKDIR\SDK\clients\java\org.eclipse.paho.client.mqttv3.jar" org.eclipse.paho.sample.mqttv3app.Sample -a subscribe
- On AIX or Linux systems, enter the following commands in a shell
window:
java -cp CLIENTPACKDIR/SDK/clients/java/org.eclipse.paho.sample.mqttv3app.jar: CLIENTPACKDIR/SDK/clients/java/org.eclipse.paho.client.mqttv3.jar org.eclipse.paho.sample.mqttv3app.Sample -a subscribe
- On Windows systems, enter the following commands in
a command line:
-
Run the mqttv3app sample Java application to publish to the subscription.
- On Windows systems, enter the following command in a
second command line:
java -cp "CLIENTPACKDIR\SDK\clients\java\org.eclipse.paho.sample.mqttv3app.jar; CLIENTPACKDIR\SDK\clients\java\org.eclipse.paho.client.mqttv3.jar" org.eclipse.paho.sample.mqttv3app.Sample -m "Hello from an MQTT v3 application"
- On AIX or Linux systems, enter the following command in a second shell
window:
java -cp CLIENTPACKDIR/SDK/clients/java/org.eclipse.paho.sample.mqttv3app.jar: CLIENTPACKDIR/SDK/clients/java/org.eclipse.paho.client.mqttv3.jar org.eclipse.paho.sample.mqttv3app.Sample -m "Hello from an MQTT v3 application"
- On Windows systems, enter the following command in a
second command line:
- Press Enter in the first command line or shell window to end the subscribing application.
-
Remove the queue manager created by the SampleMQM script.
- On Windows systems, enter the following command in a
command line:
MQINSTDIR\mqxr\samples\CleanupMQM.bat
- On AIX or Linux systems, enter the following command in a shell window:
MQINSTDIR/mqxr/samples/CleanupMQM.sh
- On Windows systems, enter the following command in a
command line:
Results
If the scripts finished, and messages can be sent and received, the MQ Telemetry installation is verified.
What to do next
If you encounter any problems during the verification process, see MQ Telemetry troubleshooting. We can also view the error log:- On Windows systems, the default location for the queue manager log is MQINSTDIR\qmgrs\MQXR_SAMPLE_QM\mqxr
- On AIX and Linux systems, the default location for the queue manager log is /var/mqm/qmgrs/MQXR_SAMPLE_QM/mqxr/