You can use the MQ source connector to copy data from IBM MQ into Event Streams or Apache Kafka. The connector copies messages from a source MQ queue to a target Kafka topic.
Kafka Connect can be run in standalone or distributed mode. This document contains steps for running the connector in distributed mode in a Docker container. In this mode, work balancing is automatic, scaling is dynamic, and tasks and data are fault-tolerant. For more details on the difference between standalone and distributed mode see the explanation of Kafka Connect workers.
Prerequisites
The connector runs inside the Kafka Connect runtime, which is part of the Apache Kafka distribution. Event Streams does not run connectors as part of its deployment, so you need an Apache Kafka distribution to get the Kafka Connect runtime environment.
Ensure you have the following available:
- IBM MQ v8 or later installed. Note: These instructions are for IBM MQ v9 running on Linux. If you’re using a different version or platform, you might have to adjust some steps slightly.
Setting up the queue manager
These sample instructions set up an IBM MQ queue manager that uses its local operating system to authenticate the user ID and password. The user ID and password you provide must already be created on the operating system where IBM MQ is running.
- Log in as a user authorized to administer IBM MQ, and ensure the MQ commands are on the path.
- Create a queue manager with a TCP/IP listener on port 1414:
crtmqm -p 1414 <queue_manager_name>for example to create a queue manager calledQM1usecrtmqm -p 1414 QM1
- Start the queue manager:
strmqm <queue_manager_name>
- Start the runmqsctool to configure the queue manager:runmqsc <queue_manager_name>
- In runmqsc, create a server-connection channel:DEFINE CHANNEL(<channel_name>) CHLTYPE(SVRCONN)
- Set the channel authentication rules to accept connections requiring userid and password:
    - SET CHLAUTH(<channel_name>) TYPE(BLOCKUSER) USERLIST('nobody')
- SET CHLAUTH('*') TYPE(ADDRESSMAP) ADDRESS('*') USERSRC(NOACCESS)
- SET CHLAUTH(<channel_name>) TYPE(ADDRESSMAP) ADDRESS('*') USERSRC(CHANNEL) CHCKCLNT(REQUIRED)
 
- Set the identity of the client connections based on the supplied context (the user ID):
ALTER AUTHINFO(SYSTEM.DEFAULT.AUTHINFO.IDPWOS) AUTHTYPE(IDPWOS) ADOPTCTX(YES)
- Refresh the connection authentication information:
REFRESH SECURITY TYPE(CONNAUTH)
- Create a queue for the Kafka Connect connector to use:
DEFINE QLOCAL(<queue_name>)
- Authorize the IBM MQ user ID to connect to and inquire the queue manager:
   SET AUTHREC OBJTYPE(QMGR) PRINCIPAL('<user_id>') AUTHADD(CONNECT,INQ)
- Authorize the IBM MQ user ID to use the queue:
   SET AUTHREC PROFILE(<queue_name>) OBJTYPE(QUEUE) PRINCIPAL('<user_id>') AUTHADD(ALLMQI)
- Stop the runmqsctool by typingEND.
For example, for a queue manager called QM1, with user ID alice, creating a server-connection channel called MYSVRCONN and a queue called MYQSOURCE, you run the following commands in runmqsc:
DEFINE CHANNEL(MYSVRCONN) CHLTYPE(SVRCONN)
SET CHLAUTH(MYSVRCONN) TYPE(BLOCKUSER) USERLIST('nobody')
SET CHLAUTH('*') TYPE(ADDRESSMAP) ADDRESS('*') USERSRC(NOACCESS)
SET CHLAUTH(MYSVRCONN) TYPE(ADDRESSMAP) ADDRESS('*') USERSRC(CHANNEL) CHCKCLNT(REQUIRED)
ALTER AUTHINFO(SYSTEM.DEFAULT.AUTHINFO.IDPWOS) AUTHTYPE(IDPWOS) ADOPTCTX(YES)
REFRESH SECURITY TYPE(CONNAUTH)
DEFINE QLOCAL(MYQSOURCE)
SET AUTHREC OBJTYPE(QMGR) PRINCIPAL('alice') AUTHADD(CONNECT,INQ)
SET AUTHREC PROFILE(MYQSOURCE) OBJTYPE(QUEUE) PRINCIPAL('alice') AUTHADD(ALLMQI)
END
The queue manager is now ready to accept connection from the connector and get messages from a queue.
Configuring the connector to connect to MQ
The connector requires details to connect to IBM MQ and to your Event Streams or Apache Kafka cluster. You can generate the sample connector configuration file for Event Streams from either the UI or the CLI. For distributed mode the configuration is in JSON format and in standalone mode it is a .properties file.
The connector connects to IBM MQ using a client connection. You must provide the following connection information for your queue manager:
- The name of the IBM MQ queue manager.
- The connection name (one or more host and port pairs).
- The channel name.
- The name of the source IBM MQ queue.
- The user name and password if the queue manager is configured to require them for client connections.
- The name of the target Kafka topic.
Using the UI
Use the UI to download a .json file which can be used in distributed mode.
- Log in to the Event Streams UI from a supported web browser (see how to determine the login URL for your Event Streams UI).
- Click Toolbox in the primary navigation and scroll to the Connectors section.
- Go to the Add connectors to your Kafka Connect environment tile and click Connecting to IBM MQ?
- Ensure the MQ Sourcetab is selected and click on the Download MQ Source Configuration, this will display another window.
- Use the relevant fields to alter the configuration of the MQ Sourceconnector.
- Click Download to generate and download the configuration file with the supplied fields.
- Open the downloaded configuration file and change the values of mq.user.nameandmq.passwordto the username and password that you used to configure your instance of MQ.
Using the CLI
Use the CLI to download a .json or .properties file which can be used in distributed or standalone mode.
- Log in to your cluster as an administrator by using the IBM Cloud Private CLI:
 cloudctl login -a https://<cluster-address>:<cluster-router-https-port>
- Run the following command to initialize the Event Streams CLI on the cluster:
 cloudctl es init
- Run the connector-config-mq-sourcecommand to generate the configuration file for theMQ Sourceconnector.
 For example, to generate a configuration file for an instance ofMQwith the following information: a queue manager calledQM1, with a connection point oflocalhost(1414), a channel name ofMYSVRCONN, a queue ofMYQSOURCEand connecting to the topicTSOURCE, run the following command:cloudctl es connector-config-mq-source --mq-queue-manager="QM1" --mq-connection-name-list="localhost(1414)" --mq-channel="MYSVRCONN" --mq-queue="MYQSOURCE" --topic="TSOURCE" --file="mq-source" --jsonNote: Omitting the --jsonflag will generate amq-source.propertiesfile which can be used for standalone mode.
- Change the values of mq.user.nameandmq.passwordto the username and password that you used to configure your instance of MQ.
The final configuration file will resemble the following:
{
	"name": "mq-source",
	"config": {
		"connector.class": "com.ibm.eventstreams.connect.mqsource.MQSourceConnector",
		"tasks.max": "1",
		"topic": "TSOURCE",
		"mq.queue.manager": "QM1",
		"mq.connection.name.list": "localhost(1414)",
		"mq.channel.name": "MYSVRCONN",
		"mq.queue": "MYQSOURCE",
		"mq.user.name": "alice",
		"mq.password": "passw0rd",
		"mq.record.builder": "com.ibm.eventstreams.connect.mqsource.builders.DefaultRecordBuilder",
		"key.converter": "org.apache.kafka.connect.storage.StringConverter",
		"value.converter": "org.apache.kafka.connect.storage.StringConverter"
	}
}
A list of all the possible flags can be found by running the command cloudctl es connector-config-mq-source --help. Alternatively, See the sample properties file for a full list of properties you can configure, and also see the GitHub README for all available configuration options.
Downloading the MQ Source connector
- Log in to the Event Streams UI from a supported web browser (see how to determine the login URL for your Event Streams UI).
- Click Toolbox in the primary navigation and scroll to the Connectors section.
- Go to the Add connectors to your Kafka Connect environment tile and click Connecting to IBM MQ?
- Ensure the MQ Sourcetab is selected and click on the Download MQ Source JAR, this will download theMQ SourceJAR file.
Configuring Kafka Connect
Event Streams provides help with getting a Kafka Connect Environment.
Follow the steps in set up Kafka Connect to get Kafka Connect running. When adding connectors add the MQ connector you downloaded earlier.
Verify that the MQ source connector is available in your Kafka Connect environment:\
$ curl http://localhost:8083/connector-plugins
[{"class":"com.ibm.eventstreams.connect.mqsource.MQSourceConnector","type":"source","version":"1.1.0"}]
Verify that the connector is running. For example, If you started a connector called mq-source:\
$ curl http://localhost:8083/connectors
[mq-source]
Verify the log output of Kafka Connect includes the following messages that indicate the connector task has started and successfully connected to IBM MQ:
 INFO Created connector mq-source
 INFO Connection to MQ established
Send a test message
- To add messages to the IBM MQ queue, run the amqsputsample and type in some messages:
 /opt/mqm/samp/bin/amqsput <queue_name> <queue_manager_name>
- Log in to the Event Streams UI from a supported web browser (see how to determine the login URL for your Event Streams UI).
- Click Topics in the primary navigation and select the connected topic. Messages will appear in the message browser of that topic.
Advanced configuration
For more details about the connector and to see all configuration options, see the GitHub README.