Drive digital transformation using Enterprise Messaging and Event Streaming
Author(s): Carlos Hirata, Ravi Katikala
Last updated: October 2020
Duration: 60 mins
We installed IBM MQ v9.1.4 and IBM Event Streams v10 on to IBM Cloud Pak® for Integration 2020.3.1 on Red Hat® Openshift® 4.4. You can use the Kafka Connect source connector for IBM MQ to copy data from IBM MQ into IBM Event Streams or Apache Kafka. Path
- Introduction
- Prepare the environment
- Configure IBM MQ
- Configure IBM Event Streams toolkit
- Setup Kafka Connect
- Setup MQ Connectors
- Configuring and running MQ Connectors
- Testing MQ Connectors
- Using Operations Dashboard (tracing)
- Summary
Introduction
The most interesting and impactful new applications in an enterprise are the applications that provide new ways of interacting with existing systems by reacting in real time to mission-critical data. Leverage your existing investments, skills and even existing data, and use event-driven techniques to offer more-responsive and more-personalized experiences. IBM Event Streams has supported connectivity to the systems you’re already using. By combining the capabilities of IBM Event Streams event streams and message queues, you can combine your transaction data with real-time events to create applications and processes. These applications and processes allow you to react to situations quickly and provide a greater personalized experience. In this tutorial, you create a bidirectional connection between IBM MQ (MQ) and Event Streams by creating two message queues and two event stream topics. One is for sending and one for receiving. You then configure the message queue source and sync connectors in order to connect between the two instances. The connector copies messages from a source MQ queue to a target Event Streams topic. There is also an MQ sink connector that takes messages from an Event Streams topic and transfers them to an MQ queue. Running it is similar to the source connector. In this lab, we will only cover the source and sink connectors. We will then configure the source a sink connector to run some tests to a local stand-alone worker. We then adjust our configuration to send the messages to a topic in Event Streams and run a console consumer to consume the messages.
Takeaways
- Configuring MQ to send and receive messages and events- Configuring Event Streams topics- Configuring MQ Source and Sync Connectors- Configuring Kafka Connect and connectors- Setting up and running MQ connectors source and sink- Using Event Streams Monitoring- Using tracing for MQ
Task 1 - Prepare the environment
Note: If your using this tutorial in a multi-user ROKS setup, the environment is already prepared for you. Please login to the cluster using LDAP authentication and the credentials provided by your instructor and jump to Configuring IBM MQ. Also, maske sure that you use a prefix provided by the instructor for queue, topic and server names.
Because this is a new deployment of the Cloud Pak for Integration that uses Red Hat OpenShift, you need to run some steps to prepare the environment. Initial setup steps are only needed for a fresh installation of the Cloud Pak. They do not need to be repeated.
Note: For this lab, we based on MAC workstation (MAC OSX)
Requirements:
- Java Version:java version "1.8.0_261"Java(TM) SE Runtime Environment (build 1.8.0_261-b12)Java HotSpot(TM) 64-Bit Server VM (build 25.261-b12, mixed mode)- Maven:https://maven.apache.org/- Git:https://git-scm.com/- Openshift CLI installed
1.In your workstation open a browser and enter http://cloud.ibm.com and enter your ibmid and click continue and password to login IBM Cloud.
data:image/s3,"s3://crabby-images/bd92d/bd92d9bb34e0637c80f576ffcc71f3385c713b9a" alt="ibm cloud login ibm cloud login"
2.Enter your IBM userid and the password and then enter the verify code.
data:image/s3,"s3://crabby-images/e517e/e517e25c172d22f5083cfbd34a0d42d5633584ee" alt="ibm cloud sign in ibm cloud sign in"
3.In the IBM Cloud Dashboard. You see all information about the infrastructure. On the left, click the Openshift icon.
data:image/s3,"s3://crabby-images/a347e/a347eef1e4f5c9b4730b81330bc09466d9dd6b97" alt="ibm cloud dashboard openshift ibm cloud dashboard openshift"
4.Click your Cluster link.
data:image/s3,"s3://crabby-images/1f76e/1f76e05c61b6b6c605f900a5e7dcc788f4f308cf" alt="ibm cloud openshift clusters ibm cloud openshift clusters"
5.Click Openshift web console.
data:image/s3,"s3://crabby-images/62dd0/62dd0c15c913bbcb04e7db9d513154938ca80a5b" alt="ibm clould openshift console ibm clould openshift console"
6.In the OpenShift console. Select the following:
1. **Networking** .2. **Routes** .3. Drill down the Project to **cp4i** .4. Click link to access Cloud Pak for Integration .
data:image/s3,"s3://crabby-images/689f4/689f4588f6f13cc90af86de1f7dc791c366e5e16" alt="ibm cloud acces cp4i 1 ibm cloud acces cp4i 1"
7.Click Default authentication as authentication type.
data:image/s3,"s3://crabby-images/e8474/e8474589e63618f4d5261ae43681ee11e0369614" alt="ibm cloud cp4i default ibm cloud cp4i default"
8.You might need to login screen for IBM Cloud Pak might be displayed, enter the username: admin and Password (Enter the 32 characters password that you created when you made the Cloud Pak provisioning) and Click Log in. Tip: You might need to use the password. You can use the Clipboard to save the password.
data:image/s3,"s3://crabby-images/2288c/2288c26829c0cc9fd0f3235a3840faf694cc769b" alt="ibm cloud cp4i login ibm cloud cp4i login"
9.In the Cloud Pak Welcome page, you see Capabilities and Runtimes instances.
data:image/s3,"s3://crabby-images/9d02a/9d02a0da425a9796428c73e142986db19c65ffc4" alt="ibm cloud welcome capabilities ibm cloud welcome capabilities"
Task 2 - Configuring MQ
In this task, you work with the MQ Console, create two queues (MQTOEVENT and EVENTTOMQ), and change MQ Authorization. The IBM MQ Operator for Red Hat OpenShift Container Platform provides an easy way to manage the lifecycle of IBM MQ queue managers. You need some configuration files from Github.
Connectors are available for copying data in both directions:
• Kafka Connect **source** connector for IBM MQ:You can use the MQ source connector to copy data from IBM MQ into IBM Event Streams or Apache Kafka. The connector copies messages from a source MQ queue to a target Kafka topic.• Kafka Connect **sink** connector for IBM MQ:You can use the MQ sink connector to copy data from IBM Event Streams or Apache Kafka into IBM MQ. The connector copies messages from a Kafka topic into an MQ queue.
1.Open a browser and enter: https://github.com/ibm-cloudintegration/dte-labs/tree/master/Lab4-DriveDigitalTransformation/resources and select es-mq.zip file.
data:image/s3,"s3://crabby-images/180aa/180aa3630f3fa474d631ccefc36c453c7d3399ca" alt="lab4 github es mq lab4 github es mq"
2.Click Download.
data:image/s3,"s3://crabby-images/f7af5/f7af58bbb57b2de8a05443173e51f05c120f19db" alt="lab4 download git lab4 download git"
3.Open a terminal window and enter unzip es-mq.zip. Unzip creates a directory es-mq in ~/Downloads directory. (Note: Use this directory as your work directory and delete after you finish the lab).
data:image/s3,"s3://crabby-images/713a4/713a4a0983a81c90901df01bf5a6d922dc39ff85" alt="lab4 unzip es mq lab4 unzip es mq"
4.You need to login to the Openshift Cluster. Go to Openshift Console and locate IAM(your ibm userid) and click Copy Login Command.
data:image/s3,"s3://crabby-images/7efbc/7efbc595d11c5b09b0a0d242b6436a93cdfa3128" alt="ibm cloud login command ibm cloud login command"
5.Click Display Token.
data:image/s3,"s3://crabby-images/c0fad/c0fad11618f45dfc78498585b88a0a85fe0b3e10" alt="ibm cloud display token ibm cloud display token"
6.Copy the line oc login —token= …. (all line).
data:image/s3,"s3://crabby-images/d30a0/d30a0bc5787bf1932abddb87379941f82c0dbf5c" alt="ibm cloud copy oc ibm cloud copy oc"
7.In terminal window, go to ~/Downloads/es-mq directory and Paste the oc login command.
data:image/s3,"s3://crabby-images/5e4f1/5e4f1ed60d40d51a9517a80d8b0499227ddf8546" alt="ibm cloud oc login ibm cloud oc login"
8.In es-mq directory, run loadmq shell script (./loadmq.sh) and you see mq configuration being loaded. This shell script loads server channels and changes some securities configurations.
data:image/s3,"s3://crabby-images/0f56e/0f56e902823960055ae59de9f17027ad4a2d82c2" alt="lab4 loading mq conf lab4 loading mq conf"
9.Prepare IBM MQ to exchange data from IBM Event Streams. You run a script file that configures MQ server (Security and Server Channel). The script creates two server channels: EVENTTOMQ and MQTOEVENT. In your browser, go to the IBM Cloud Pak Platform. You might need to log in to IBM Cloud Pak. The username and password are already cached (admin/(Enter the 32 characters password that you created when you made the Cloud Pak provisioning)). Click Log in.
data:image/s3,"s3://crabby-images/dc21d/dc21d40eee9f5680c90372f88247fd94039247ce" alt="ibm cloud login cp4i ibm cloud login cp4i"
10.In the Welcome page of the IBM Cloud Pak for Integration, click Runtimes and locate the Queue Manager in Instance Type and click mq-demo.
data:image/s3,"s3://crabby-images/424fc/424fc3c36eb21398f657f592ecfb87994b818674" alt="lab4 cp4i welcomepage lab4 cp4i welcomepage"
11.Firefox might warn you about a potential security risk. Click Advanced then accept the risk and Continue. 12.In Welcome to IBM MQ page, you can run and access MQ information. Click Create a queue.
data:image/s3,"s3://crabby-images/8b9b7/8b9b73bd9dbea1fdde5b305ccc2fb1a3a40a057e" alt="lab4 create queue lab4 create queue"
13.In Create a queue page, choose queue type: Click Local.
data:image/s3,"s3://crabby-images/a9176/a91767948b01479f7e53b5faedb8e2a1c75e1ca7" alt="lab4 create local queue lab4 create local queue"
14.In the Create a queue page. Enter in the Queue name: MQSOURCE. Click Create.
data:image/s3,"s3://crabby-images/c1507/c1507ad7730ab973a1509ed84e246f5dfd0807a1" alt="lab4 create mqsource lab4 create mqsource"
15.And again, click Create a queue in Welcome to IBM MQ page.
data:image/s3,"s3://crabby-images/8b9b7/8b9b73bd9dbea1fdde5b305ccc2fb1a3a40a057e" alt="lab4 create queue lab4 create queue"
16.On the Choose queue type, click Local.
data:image/s3,"s3://crabby-images/a9176/a91767948b01479f7e53b5faedb8e2a1c75e1ca7" alt="lab4 create local queue lab4 create local queue"
17.Enter the queue name: MQSINK and click Create.
data:image/s3,"s3://crabby-images/4ea34/4ea348272634d716c7b6a92e59a633d3c586b477" alt="lab4 create mqsink lab4 create mqsink"
18.Click Manage on the menu to check MQ configurations.
data:image/s3,"s3://crabby-images/36632/3663271fcc27935340e1c1f6743df4a88080a34f" alt="lab4 manage queue manager lab4 manage queue manager"
19.Verify the queues that you created and queue manager name: QUICKSTART. Click Communications to verify the channels.
data:image/s3,"s3://crabby-images/82ab9/82ab9c50e772844a78be41f88d7aaf04b316cc53" alt="lab4 queue manager communication lab4 queue manager communication"
20.Verify the server channels are created. Click App channels. See the server channels that the loadmq script created: EVENTTOMQ to connect Event Streams to MQ and MQTOEVENT to connect MQ to Event Streams.
data:image/s3,"s3://crabby-images/3b53e/3b53e619897364716d4b0707459d7bdacac00f5f" alt="lab4 check server channels lab4 check server channels"
21.To connect to MQ (QUICKSTART), you need MQ server Address. In the Terminal. To get MQ server address, enter the OpenShift commands:
1. oc get svc | grep mq (list the mq services).2. Copy the address of mq-demo-ibm-mq (**172.21.216.195**) – This address might be different.
Task 3 - Configuring Event streams
Now that you are familiar with topics and creating them from the previous labs, you need to create a new topic for running the MQ source connector. The connector requires details to connect to IBM MQ and to your IBM Event Streams or Apache Kafka cluster. 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: QUICKSTART• The connection name (one or more host and port pairs): * This is the MQ host address or IP address.• The channel name:• Sink: EVENTTOMQ• Source: MQTOEVENT• The name of the source IBM MQ queue: MQSOURCE• The name of the sink IBM MQ queue: MQSINK• The name of the target Kafka topic: mqtoevent• The name of the origin Kafka topic: eventtomq
1.Open a browser and go to the IBM Cloud Pak Platform. Select Runtimes and click es-demo for Event Streams.
data:image/s3,"s3://crabby-images/384cb/384cb4dd06ef36450f19f36bddc409c910900471" alt="lab4 runtimes es demo lab4 runtimes es demo"
2.In Welcome to IBM Event Streams page, click Create a topic on the menu bar
data:image/s3,"s3://crabby-images/20b32/20b3226351a4e2e190e9d028aea8e6f671506282" alt="lab4 create topic lab4 create topic"
3.In the Create topic. Turn Show all available options to On. Use the following values when creating the topics. Create the following topics:
1. Topic Name field, enter: **eventtomq**.2. Keep, Partitions: 1 (A partition is an ordered list of messages).3. Keep, Replicas: 3 (In order to improve availability, each topic can be replicated onto multiple brokers).4. Keep, Minimum in-sync replicas: 2 - (In order to improve availability, each topic can be replicated onto multiple brokers).5. Keep, Retention time: 10 minutes - (It Is time messages are retained before being deleted).6. Click Create topic.
data:image/s3,"s3://crabby-images/028ed/028edb486900fdca7c307c62afb79b18d826d28f" alt="lab4 create topic eventtomq lab4 create topic eventtomq"
4.Repeat step 3, and create a topic mqtoevent. Note: When all available options are On, you see a great amount of detail for each topic. You only need to edit the Core configuration section. If you turn the switch to Off, you need to click Next three times before the final pane where you click Create topic.
Task 4 - Setup Kafka Connect
You can integrate external systems with IBM Event Streams by using the Kafka Connect framework and connectors. Use Kafka Connect to reliably move large amounts of data between your Kafka cluster and external systems. For example, it can ingest data from sources such as databases and make the data available for stream processing. Kafka Connect uses connectors for moving data into and out of Kafka. Source connectors import data from external systems into Kafka topics, and sink connectors export data from Kafka topics into external systems. A wide range of connectors exists, some of which are commercially supported. In addition, you can write your own connectors.
1.In Event Streams Topics, verify if the eventtomq and mqtoevent topics are created. Click Connect to this cluster. Kafka Connect uses an Apache Kafka client just like a regular application, and the usual authentication and authorization rules apply. Kafka Connect needs authorization to:
1. Produce and consume to the internal Kafka Connect topics and, if you want the topics to be created automatically, to create these topics2. Produce to the target topics of any source connectors you are using3. Consume from the source topics of any sink connectors you are using
data:image/s3,"s3://crabby-images/4e2f7/4e2f75425c86d0ac2604432927b8f0ec5b049d34" alt="lab4 connect to this cluster lab4 connect to this cluster"
2.In Cluster connection page, save listener External (1): es-qs-kafka-bootstrap-eventstreams.apps.demo.ibmdte.net:443 (this address might be different) in a file and then click Generate SCRAM credentials. (https://en.wikipedia.org/wiki/Salted_Challenge_Response_Authentication_Mechanism).
data:image/s3,"s3://crabby-images/e8a80/e8a80fa39c2fb0e375a4e97f1f78d1c871bff8b0" alt="lab4 cluster connection external lab4 cluster connection external"
3.Enter the credential name (kafkauser): mqeventstreams, check Produce, consume messages and create topics and schemas and click Next.
data:image/s3,"s3://crabby-images/ab3ef/ab3ef1d227b06b65ae4c345ac0ec16d01c596148" alt="lab4 generate credentials 1 lab4 generate credentials 1"
4.In Which topics does the application need to access?, check All topics and click Next.
data:image/s3,"s3://crabby-images/a3fe7/a3fe71366cfbd197b080c73f29aa9292fb7fc560" alt="lab4 which topics does the application lab4 which topics does the application"
5.In Which consumer group does the application need to access?, check All consumer groups and click Next.
data:image/s3,"s3://crabby-images/a3fe7/a3fe71366cfbd197b080c73f29aa9292fb7fc560" alt="lab4 which topics does the application lab4 which topics does the application"
6.In Choose which transactional IDs the application can access, select No transactional IDs and click Generate credentials.
data:image/s3,"s3://crabby-images/08db3/08db33dd3479b4abafa960afb8df0efbee8f5283" alt="lab4 choose which transactional lab4 choose which transactional"
7.In Cluster connection. Event Streams generates the SCRAM Credentials as username and password. Your username is mqeventstreams.
data:image/s3,"s3://crabby-images/5bf41/5bf41528fb534835606ad5a9132a31264a5d27a9" alt="lab4 scram username lab4 scram username"
8.Click Toolbox. For this lab, you run two connectors (Sink and Source) as distributed mode. When running in distributed mode, Kafka Connect uses three topics to store configuration, current offsets and status. Kafka Connect can create these topics automatically as it is started by the Event Streams operator. By default, the topics are:
1. connect-configs: This topic stores the connector and task configurations.2. connect-offsets: This topic stores offsets for Kafka Connect.3. connect-status: This topic stores status updates of connectors and tasks.(If you want to run multiple Kafka Connect environments on the same cluster, you can override the default names of the topics in the configuration).
data:image/s3,"s3://crabby-images/19c51/19c51db78312032351b417e973816e6a5ec8e275" alt="lab topics toolbox lab topics toolbox"
9.In Toolbox page, locate Connectors and click Set up in Setup a Kafka Connect environment.
data:image/s3,"s3://crabby-images/8650a/8650aae522dbb4fb5f2ea5c337c6cb829f45cde9" alt=""
10.To set up the Kafka connect environment. Click Download Kafka Connect ZIP to download the compressed file, then extract the contents to your preferred location. The default location is your ~/Downloads directory. (Do not close the browser).
data:image/s3,"s3://crabby-images/736c6/736c6d4aba3bd6844a48d42c5a38b06e7b080e33" alt="lab4 setup kafka connect lab4 setup kafka connect"
11.Open a terminal window. move ~/Downloads/kafkaconnect.zip to ~/Downloads/es-mq directory (use mv ~/Downloads/kafkaconnect.zip ~/Downloads/es-mq).
data:image/s3,"s3://crabby-images/1c813/1c813fd6ef5fbadf9479f8da1f59244d54e35d84" alt="lab4 move kafkaconnect lab4 move kafkaconnect"
12.Extract the files in kafkaconnect.zip. Execute unzip kafkaconnect.zip. You have a Kubernetes manifest for a KafkaConnectS2I and an empty directory called my-plugins.
data:image/s3,"s3://crabby-images/64e10/64e105380fbdc147bd70cd768b696a4b677937d6" alt="lab4 unzip kafkaconnect lab4 unzip kafkaconnect"
13.Provide authentication credentials in authentication configuration. Using the opened terminal window, enter oc get secrets | grep es-demo, locate es-demo-cluster-ca-cert.
data:image/s3,"s3://crabby-images/c7dad/c7dad95db01c904ad809408eaa16cf946b4766b9" alt="lab4 es demo cluster ca lab4 es demo cluster ca"
- In the Terminal, go to ~/Downloads/es-mq directory and edit kafka-connect-s2i.yaml. (We created a copy of kafka-connect-s2i as kafka-connect-s2i.original). Use kafka-connect-s2i.original as kafka-connect-s2i.yaml.(Do this mv kafka-connect-s2i.original kafka-connect-s2i.yaml). If your using kafka-connect-s2i.original, update the Event Streams bootstrapServers.
1. Verify the name of kafka connector: my-labconnect-cluster2. Enter Event Streams bootstrapServers (This address is different): es-demo-kafka-bootstrap-cp4i.mycluster-dal12-c-636918-4e85092308b6e4e8c206c47df210f622-0000.us-south.containers.appdomain.cloud:443.3. The productVersion should be changed to 10.1.0.4. The productChargedContainers should be my-labconnect-cluster.5. The cloudpakVersion should be: 2020.3.1 .6. We added this line and enter connection timeout in config: connection.timeout.ms: 50000.7. We added this line and enter read timeout in config: read.timeout.ms: 50000.Remove all “#”.8. Enter es-demo-cluster-ca-cert as tls->trustedCertificates->secretname.
data:image/s3,"s3://crabby-images/ef8f7/ef8f7754af98463946e426cafc3067fa9155ea73" alt="lab4 edit kafka connector lab4 edit kafka connector"
15.Deploy Kafka connect, in the terminal window in the ~/Downloads/es-mq directory.
1. Enter oc apply -f kafka-connect-s2i.yaml.2. Enter oc get kafkaconnects2i to verify the Kafka connect instance has been created.
data:image/s3,"s3://crabby-images/41b61/41b61eba1f8607004eb268f916cec91fe88df741" alt="lab4 oc apply kafka lab4 oc apply kafka"
16.You have created a Kafka instance as OpenShift Operator, open a browser and go to OpenShift console.
1. Select Operators->Installed Operators.2. Set Project: eventstreams. Click IBM Event Streams.3. Click Kafka Connect Source to Image.
data:image/s3,"s3://crabby-images/ce0c0/ce0c04590d523bd50f26c8010e14b88a70907f52" alt="lab4 check kafka connect operators lab4 check kafka connect operators"
Task 5 - Setup MQ connectors
The Event Streams connector catalog contains a list of tried and tested connectors from both the community and IBM®. Go to this page and check the IBM supported connectors (https://ibm.github.io/event-streams/connectors/).
Before you run this Task, check if you have these requirements:
- Java Version:java version "1.8.0_261"Java(TM) SE Runtime Environment (build 1.8.0_261-b12)Java HotSpot(TM) 64-Bit Server VM (build 25.261-b12, mixed mode)- Maven:https://maven.apache.org/
1.Back to Set up Kafka Connect environment (you should keep the browser opened). Add two connectors in Kafka Connect Environment, select Add connectors to your Kafka Connect environment.
data:image/s3,"s3://crabby-images/6cbe8/6cbe850bb79367498396e7876b1a2bd75608de4c" alt="lab4 add mq connectors lab4 add mq connectors"
2.In Add connectors to your Kafka Connect environment, click IBM MQ Connectors.
data:image/s3,"s3://crabby-images/d01f3/d01f34712ddc0cf15439d580fb186696b44680b9" alt="lab4 add ibm mq connectors lab4 add ibm mq connectors"
3.You can move data between Event Streams and IBM MQ. Add two connectors in the Kafka Connect environment. Download MQ Source the connector JAR and configuration. Click Go to GitHub.
data:image/s3,"s3://crabby-images/49b51/49b519872e6d36dd46c7e780ec4259a9a825f7d9" alt="lab4 MQSource git lab4 MQSource git"
4.In the GitHub, locate Build the connector copy git clone https://github.com/ibm-messaging/kafka-connect-mq-source.git
data:image/s3,"s3://crabby-images/ff7de/ff7de2aa429404ad961e61a9fed056971ff7d358" alt="lab4 git mqsource connector lab4 git mqsource connector"
5.Open a terminal window and go to ~/Donwloads/es-mq directory and Paste git clone https://github.com/ibm-messaging/kafka-connect-mq-source.git.
data:image/s3,"s3://crabby-images/a1aaf/a1aaf8b1c34f05dfc795819a139918c1891ff03a" alt="lab4 run git mqsource lab4 run git mqsource"
6.Go to the directory that Git creates ~/Downloads/es-mq/kafka-connect-mq-source and enter mvn clean package (you should have to install MAVEN (https://maven.apache.org/ ) to build the connector (kafka-connect-mq-source-1.3.1-jar-with-dependencies.jar) using Maven. In the connector kafka-connect-mq-source-1.3.1-jar-with-dependencies.jar is this directory: ~/Downloads/es-mq/kafka-connect-mq-source/target/
data:image/s3,"s3://crabby-images/41bc8/41bc8c103c808f3744f745cc47e265a8a0bdab53" alt="lab4 run mqven mqsource lab4 run mqven mqsource"
7.Back to IBM Connectors. To run IBM MQ Connector, you need mq-source properties file. This tool generates mq-source.json file, for our lab you need mq-source.yaml file. We generated for you in ~/Download/es-mq directory.
8.Edit the mq-source.yaml. Update the mq.connection.name.list (you should save).
data:image/s3,"s3://crabby-images/d4ad9/d4ad97435e4409d9e0cbbd4ee756691f5ef3ddf6" alt="lab4 mqsource yaml lab4 mqsource yaml"
9.Change to MQ Sink in IBM MQ connectors page, clicking MQ Sink and then click Go to GitHub.
data:image/s3,"s3://crabby-images/86be0/86be00ad2328678925437badb21a026ac50c49af" alt="lab4 MQSink git lab4 MQSink git"
10.In the GitHub, locate Build the connector copy git clone https://github.com/ibm-messaging/kafka-connect-mq-sink.git .
data:image/s3,"s3://crabby-images/b4a5a/b4a5ab3e3e21c3fe80283cb6846bd9d7a70712c7" alt="lab4 git mqsink connector lab4 git mqsink connector"
11.Open a terminal window and go to ~/Downloads/es-mq directory and Paste git clone https://github.com/ibm-messaging/kafka-connect-mq-sink.git.
data:image/s3,"s3://crabby-images/716af/716afb7874f1ae75d5757c67f061098e7a739ba4" alt="lab4 run git mqsink lab4 run git mqsink"
12.Go to the directory that git creates ~/Downloads/es-mq/kafka-connect-mq-sink and enter mvn clean package to build the connector (kafka-connect-mq-sink-1.3.1-jar-with-dependencies.jar) using Maven.
data:image/s3,"s3://crabby-images/c9213/c921353918e6d067e7bbaa25605a08cf0eb2a15e" alt="lab run maven mqsink lab run maven mqsink"
13.Back to IBM Connectors. To run IBM MQ Connector, you need mq-source properties file. This tool generates mq-sink.json file, for our lab you need mq-sink.yaml file. We generated for you in ~/Downloads/es-mq directory.
14.Edit the mq-sink.yaml. Update the mq.connection.name.list (you should save).
data:image/s3,"s3://crabby-images/4c182/4c182a7a4a748c4966f8239c5e532fee0f5f8daf" alt="lab4 mqsink yaml lab4 mqsink yaml"
Task 6 – Configuring and running MQ Connectors
In this task, start Kafka connect, you configured Kafka Connect S2I for your environment. Build Kafka Connect with MQ connectors (Sink and Source).
1.Open a terminal window and copy MQ source connector JAR file. Go to ~/Download/es-mq/kafka-connect-mq-source/target. Copy kafka-connect-mq-source-1.3.1-jar-with-dependencies.jar to ~/Downloads/home/es-mq/my-plugins (use cp ~/Downloads/es-mq/kafka-connect-mq-source/target/kafka-connect-mq-source-1.3.1-jar-with-dependencies.jar ~/Downloads/es-mq/my-plugins).
data:image/s3,"s3://crabby-images/23daa/23daad9fa8748d95a8ccdc58d4e550d36a41f414" alt="lab4 copy kafka connect mqsource lab4 copy kafka connect mqsource"
2.Do the same for MQ Sink connector JAR file. ~/Download/es-mq/kafka-connect-mq-sink/target. Copy kafka-connect-mq-sink-1.3.1-jar-with-dependencies.jar to ~/Downloads/es-mq/my-plugins (use cp ~/Downloads/es-mq/kafka-connect-mq-sink/target/kafka-connect-mq-sink-1.3.1-jar-with-dependencies.jar ~/Downloads/es-mq/my-plugins).
data:image/s3,"s3://crabby-images/d16c4/d16c48ff44e79ec7b7a399e64bc8d3c59953da64" alt="lab4 copy kafka connect sink lab4 copy kafka connect sink"
3.Go to ~/Downloads/ibmuser/es-mq directory and build Kafka connect. Enter oc start-build my-labconnect-cluster-connect —from-dir ~/Downloads/es-mq/my-plugins/ .
data:image/s3,"s3://crabby-images/706c8/706c80d1c354d468bc05a6aee76e166c613a5ec0" alt="lab4 oc start build mylab lab4 oc start build mylab"
4.Check that the build is complete. Enter oc get builds .
data:image/s3,"s3://crabby-images/da812/da8122215b6790626afabe797d7ab4462b99ff5f" alt="lab4 oc get builds lab4 oc get builds"
5.Check if pods are ready. Enter oc get pods.
data:image/s3,"s3://crabby-images/2f6e6/2f6e62e4bd51d4ab5f679a6230f2d30732d86309" alt="lab4 oc get pods lab4 oc get pods"
6.We created mq-source.yaml and mq-sink.yaml for you in ~/Downloads/es-mq directory. You can find a file sample in ~/Downloads/es-mq/es-mq/kafka-connect-mq-source/deploy/strimzi.kafkaconnector.yaml and ~/Downloads/es-mq/kafka-connect-mq-sink/deploy/strimzi.kafkaconnector.yaml.
7.Start mq-source connector. Open a terminal window and go to ~~/Downloads/es-mq directory and enter oc apply -f mq-source.yaml .
data:image/s3,"s3://crabby-images/1671b/1671b49531eb3dc1c11bc2efb857b53cb34298ef" alt="lab4 oc apply mq source lab4 oc apply mq source"
8.Start mq-sink connector. Open a terminal window and go to ~/Downloads/es-mq directory and enter oc apply -f mq-sink.yaml.
data:image/s3,"s3://crabby-images/a70e0/a70e0459fb3381fb90f73d4f68477e265e5617b2" alt="lab4 oc apply mq sink lab4 oc apply mq sink"
9.Open a browser and click OpenShift console toolbar. Change Project to cp4i and select Operators ->Installed Operators-> IBM Event Streams.
data:image/s3,"s3://crabby-images/29679/296798d2b797fd3398de8fad0b7b600f160495f3" alt="lab4 ocp operators eventstreams lab4 ocp operators eventstreams"
10.Select Kafka Connect Source to Image and check my-labconnect-cluster is Ready.
data:image/s3,"s3://crabby-images/53dd5/53dd51f994096366f3ff8572cb4299c8d87273b6" alt="lab4 ocp operators kafkaconnectsource lab4 ocp operators kafkaconnectsource"
11.Click Kafka Connector and verify two Kafka Connectors are Ready. Both connectors are running simultaneously.
data:image/s3,"s3://crabby-images/cb1e0/cb1e0b17982e9c0304d99702c070fce792240976" alt="lab4 oc operators check mq connectors lab4 oc operators check mq connectors"
Task 7 – Testing MQ Connectors
Many organizations use both IBM MQ and Apache Kafka for their messaging needs. Although they’re generally used to solve different kinds of messaging problems, users often want to connect them together for various reasons. For example, IBM MQ can be integrated with systems of record while Apache Kafka is commonly used for streaming events from web applications. The ability to connect the two systems together enables scenarios in which these two environments intersect.
1.Open a browser and go to IBM Cloud Pak for Integration. Select Runtimes and click mq-demo.
data:image/s3,"s3://crabby-images/424fc/424fc3c36eb21398f657f592ecfb87994b818674" alt="lab4 cp4i welcomepage lab4 cp4i welcomepage"
2.Select Default Authentication
data:image/s3,"s3://crabby-images/2d081/2d0814deab752e0093f2cb6e31fc85b2607425c2" alt="ibm cloud logon default ibm cloud logon default"
3.You might need to log in. Click Log in (Username and Password are cached).
data:image/s3,"s3://crabby-images/dc21d/dc21d40eee9f5680c90372f88247fd94039247ce" alt="ibm cloud login cp4i ibm cloud login cp4i"
4.In Welcome to IBM MQ page, click Manage QUICKSTART .
data:image/s3,"s3://crabby-images/265c9/265c90fa6bd2255b15dcaa010f6204878f36849e" alt="lab4 manage quicktstart lab4 manage quicktstart"
5.In Queue Manager:QUICKSTART page, click the queue MQSOURCE.
data:image/s3,"s3://crabby-images/c48ea/c48eacc27d813e6dea671eff638ad09f329c0251" alt="lab4 quickstart mqsource lab4 quickstart mqsource"
6.The Queue should be empty and to send a message, click Create .
data:image/s3,"s3://crabby-images/721d5/721d5e10868e45f40dfacd0c6ad8a571363dac9c" alt="lab4 open mqsource lab4 open mqsource"
7.Enter a message that you want to send to Event Streams and click Create (for example: Sending a message to Event Streams). Queue MQSOURCE should be empty, which indicated IBM MQ has sent the message to Event Streams
data:image/s3,"s3://crabby-images/8de18/8de180d3ff9dc7b130b70f2bedad2ef7747d67ab" alt="lab4 sending messaging to es lab4 sending messaging to es"
8.Back to IBM Cloud Pak for Integration. Select Runtimes and click es-demo. In the Welcome to IBM Event Streams, click Topics on the left.
data:image/s3,"s3://crabby-images/a71e5/a71e5f716dbddc06337c0e40ae77b9d3c7c23b15" alt="lab4 eventstreams menu topics lab4 eventstreams menu topics"
9.You see the list of topics. You created eventtomq and mqtoevent. Kafka Connector creates three more system topics, click mqtoevent& topics.
data:image/s3,"s3://crabby-images/6239a/6239a2a6999a28665197e3664608ebac3504e8dd" alt="lab4 open mqtovent topic lab4 open mqtovent topic"
10.In topics mqtoevent, click Messages and select the message.
data:image/s3,"s3://crabby-images/6c3f2/6c3f2f529a8f03357c84bc168b423424cb09a914" alt="lab4 mqtoevent message lab4 mqtoevent message"
11.Click Monitoring icon on the left and observe the Incoming and Outgoing bytes.
data:image/s3,"s3://crabby-images/1beca/1becadd5fa70285853c21e847091998901fa267b" alt="lab4 monitoring one message lab4 monitoring one message"
12.You see the incoming and outgoing bytes.
data:image/s3,"s3://crabby-images/d72e7/d72e7a86199cfff04a437622f51268336a6201b1" alt="lab4 messages list lab4 messages list"
13.You need to produce to send events to MQ queue. Go to Toolbox.
data:image/s3,"s3://crabby-images/07078/07078f4dacda60a25f3e52f2523675c720886fe6" alt="lab4 toolbox menu lab4 toolbox menu"
14.In Starter Application, click Get Started .
data:image/s3,"s3://crabby-images/e013f/e013f47a473e734d2e1f5b385ef494c4c42db839" alt="lab4 starter application lab4 starter application"
15.Go to step 1 in Configure & run starter application to download the JAR file for the starter application.
data:image/s3,"s3://crabby-images/bc66d/bc66de7321968e6c5f1d4790113194c78d20e2c0" alt="lab4 configure run starter lab4 configure run starter"
16.In the GitHub, click demo-all.jar file and download (the demo-all.jar file is in ~/Downloads).
data:image/s3,"s3://crabby-images/f5644/f564413c5a340486c2d0899624b03bbdd979c73c" alt="lab4 demojar download lab4 demojar download"
17.Back to Configure & run starter application. Go to step 2, click Generate properties .
data:image/s3,"s3://crabby-images/d60b8/d60b8795f7503dedf5b4e5d7273583b7e9eacfb3" alt="lab4 generate properties lab4 generate properties"
18.In the window generate properties:
1. Enter Starter Application Name: mqeventstreamsapp.2. Select Existing topic and click Select a topic: eventtomq.3. Click Generate and Download the compressed file.4. The file mqeventstreamsapp.properties.zip is in ~/Downloads.
data:image/s3,"s3://crabby-images/d41fb/d41fb9e7bc14c656bffc6be325d3d30ba529a688" alt="lab4 generate properties configuration lab4 generate properties configuration"
19.Open a terminal window and move ~/Downloads/demo-all.jar and mqeventstreamsapp.propeties.zip to ~Downloads/es-mq directory (use mv ~/Downloads/demo-all.jar ~/Downloads/es-mq).
20.Go to ~/Downloads/es-mq and create a directory estomq (Use mkdir -p estomq). Move, use mv ~/Downloads/mqeventstreamsapp_properties.zip to ~/Downloads/es-mq/estomq.
data:image/s3,"s3://crabby-images/6f3a6/6f3a6924b314bbbeeb6f0145b97832c6debb405a" alt="lab4 move demo jar lab4 move demo jar"
21.Go to estomq directory and extract the file (Use unzip mqeventstcdreamsapp.propeties.zip).
data:image/s3,"s3://crabby-images/50a3f/50a3fb7b1dad2b6d87bcf613b704875dead53b50" alt="lab4 unziip mqeventstreamsapp zip lab4 unziip mqeventstreamsapp zip"
22.Go to ~/Download/es-mq and run the following command with the full file path to the kafka.properties file and certificates downloaded: java -Dproperties_path=estomq -jar demo-all.jar . Check the log message: Application started in ms.
data:image/s3,"s3://crabby-images/86a96/86a96fb7b65e2168f71e7803958337c2ca083851" alt="lab4 run demo jar lab4 run demo jar"
23.Back to Configure & run starter application page. Access the started application, clicking localhost:8080.
data:image/s3,"s3://crabby-images/6a820/6a820768b9efe452bc7b2fbed0ef2c9e2e303ff6" alt="lab4 run local 8080 lab4 run local 8080"
24.Insert a message in the left window (for example, Sending events from IBM Event Streams to IBM MQ) and click Start producing and then click start consuming. Send more than 30 messages and click to stop producing and consuming.
data:image/s3,"s3://crabby-images/f2600/f260080a31ededb7bbf2bac56982a2cdb6f794a7" alt="lab4 sending event to mq lab4 sending event to mq"
25.Back to Configure & run starter application. Click Go to the message browse link.
data:image/s3,"s3://crabby-images/3e0b4/3e0b46e2a8bd769ea0bda90c9eb3142c4afdb9c7" alt="lab4 browse messages lab4 browse messages"
- See the events that have sent to MQ.
- Click Monitoring on the left and see the Incoming and Outgoing bytes.
data:image/s3,"s3://crabby-images/d72e7/d72e7a86199cfff04a437622f51268336a6201b1" alt="lab4 messages list lab4 messages list"
- Check the messages incoming and outgoing.
data:image/s3,"s3://crabby-images/abfa2/abfa21075ec8cc1728ae572eca3ba9c74494a2fb" alt="lab4 monitoring mqtoevent lab4 monitoring mqtoevent"
Open a browser and click IBM Cloud Pak for Integration. Select Runtimes and click mq-demo.
Go to mq instance and In Welcome to IBM MQ page, click the menu on the left, selecting Manage.
data:image/s3,"s3://crabby-images/265c9/265c90fa6bd2255b15dcaa010f6204878f36849e" alt="lab4 manage quicktstart lab4 manage quicktstart"
31.In Manage, verify in the Maximum depth and click the queue MQSINK.
data:image/s3,"s3://crabby-images/bb700/bb700a9a4f6017a318215c34fc815d43b28dee52" alt="lab4 messages mqtoevent queue lab4 messages mqtoevent queue"
32.Check the messages have arrived in MQSINK queue and click one message and then click Application data and see the message.
data:image/s3,"s3://crabby-images/538ca/538cac6b2c20669eb3651910f67e7df3f7a33080" alt="lab4 messages list mqsink lab4 messages list mqsink"
data:image/s3,"s3://crabby-images/766c6/766c66ab0ef121e95be4e4c5dbee24fb6bbfafd4" alt="lab4 checking a message lab4 checking a message"
Task 8 - Using Operations Dashboard (tracing)
Cloud Pak for Integration Operations Dashboard Add-on is based on Jaeger open source project and the OpenTracing standard to monitor and troubleshoot microservices-based distributed systems. Operations Dashboard can distinguish call paths and latencies. DevOps personnel, developers, and performance specialists now have one tool to visualize throughput and latency across integration components that run on Cloud Pak for Integration.
Cloud Pak for Integration Operations Dashboard Add-on is designed to help organizations that need to meet and ensure maximum service availability and react quickly to any variations in their systems.
1.Go to the IBM Cloud Pak Integration main page. In the Capabilities section, click capability type to access tracing namespace to open the Operations Dashboard instance.
data:image/s3,"s3://crabby-images/0cbf6/0cbf6a176927ec39c931bffaa7b7ec69bc9c0c2d" alt="lab4 open tracing lab4 open tracing"
2.In the Tracing page, check the Overview page. You see all products that you can use this tool: APIC, APP Connect and IBM MQ. (more tracing products will add in the future releases). Click MQ Overview.
data:image/s3,"s3://crabby-images/ff79a/ff79a341d28e3cd40f1eb4ca1a7d79e3c0be6004" alt="lab4 open mq overview lab4 open mq overview"
3.See IBM MQ overview. Click Traces.
data:image/s3,"s3://crabby-images/ae25c/ae25cb5deff3eac224b727fe1e081a73ffcbdfab" alt="lab4 open traces lab4 open traces"
4.Operations Dashboard generated a list of tracing. Select a line to analyze the trace of IBM MQ.
data:image/s3,"s3://crabby-images/9f26e/9f26e2b7452c1a646a90872d310d482019eee8d5" alt="lab4 trace list lab4 trace list"
5.Check the tracing chart. Check the number of interations.
data:image/s3,"s3://crabby-images/de596/de596591eb9d39775942c9c98ed1c7c79eb60e9a" alt="lab4 trace chart lab4 trace chart"
Summary
You have successfully completed the tutorial. You were able to add a layer of secure, reliable, event-driven, and real-time data, which can be reused across applications in your enterprise. You learned how to:
• Configure message queues • Create event streams topics • Configure message queue connectors (sink and source) • Start a test run of the flow and view the data • Analyze MQ using Operations Dashboard
To try out more labs, go to Cloud Pak for Integration Demos. For more information about the Cloud Pak for Integration, go to https://www.ibm.com/cloud/cloud-pak-for-integration.