はじめに
IBM CloudのManaged OpenShift環境で、Kafkaクラスタの検証を行うため、Red Hat AMQ StreamsをOperatorで入れた手順です。
環境概要
data:image/s3,"s3://crabby-images/fb60a/fb60a2c47b3901113de49a9a5ecb8e30166baa7a" alt="image.png"
導入手順
OpenShiftクラスタの準備
事前準備として、IBM Cloud上にOpenShiftクラスタを作成します。
本検証では、OpenShift4.5(Gen2 VPC)のクラスタを1つ作成し、AMQ Streams用にWorker Node(Flavor:bx2.4×16)を3つのAZに合計3台用意しました。
参照:https://cloud.ibm.com/docs/openshift?topic=openshift-clusters
AMQ Streamsの導入
1. Projectの作成
data:image/s3,"s3://crabby-images/9ea16/9ea160fb6627bfc0b0b45d5341dd468e532f9dd0" alt="image.png"
2. AMQ Streams Operatorの導入
data:image/s3,"s3://crabby-images/c1725/c172509200a6a5e4f389d4177b362b9ae2575ff5" alt="image.png"
data:image/s3,"s3://crabby-images/e2a87/e2a87b7df581b17c01ec7432ae619f98e11b08ce" alt="image.png"
data:image/s3,"s3://crabby-images/76df8/76df89f9cca504eaec42768c4b185bd28217b1cc" alt="image.png"
・Installed Operators画面でStatusがSucceededになることを確認します。
data:image/s3,"s3://crabby-images/c3195/c319509109c29ff48f9652064a7d63f915efd36a" alt="image.png"
data:image/s3,"s3://crabby-images/bd00d/bd00dce179ac81b7e59496f6a5107d4fdac70868" alt="image.png"
3. Kafkaクラスタの構成
data:image/s3,"s3://crabby-images/c0607/c0607765f5a6a0d777c8f0ecc8ee2627bdb4ed5e" alt="image.png"
data:image/s3,"s3://crabby-images/17d4d/17d4d3d573b96c5f45272c08acebdba9d4479968" alt="image.png"
data:image/s3,"s3://crabby-images/55bc1/55bc159b955128d24d1dbedd84a8599b55687687" alt="image.png"
data:image/s3,"s3://crabby-images/6609e/6609e48de78ffe263f2773fb03530c9a8bcde1eb" alt="image.png"
data:image/s3,"s3://crabby-images/4ac47/4ac4742553d097a239c46ba79158f79ef3fcd137" alt="image.png"
4. Zookeeperクラスタの構成
Kafka構成のForm Viewの続きで、Zookeeperクラスタの構成を行います。
data:image/s3,"s3://crabby-images/b4313/b43134c361b461d1511892539a4c41e8dba67adf" alt="image.png"
data:image/s3,"s3://crabby-images/564f8/564f869072a1426b5b6816d1e885814f2ee07339" alt="image.png"
data:image/s3,"s3://crabby-images/1b5ba/1b5ba61e9f9afa4322cbcef689d5bcc4f9ccc89b" alt="image.png"
data:image/s3,"s3://crabby-images/1b5c3/1b5c3fd2d75ea0a52a2bc7b4242a1830f4b1bcec" alt="image.png"
data:image/s3,"s3://crabby-images/25b3b/25b3bc196b0a71a33e129563b9a128bec30de1d0" alt="image.png"
data:image/s3,"s3://crabby-images/f566c/f566cbf367d660d41f098f5f72994d4bcb4c2dc7" alt="image.png"
data:image/s3,"s3://crabby-images/c1d0b/c1d0bd4ee43438ce44f3ee62bd86b9a8150cf5d1" alt="image.png"
5. Topicの作成
data:image/s3,"s3://crabby-images/d5468/d5468ed86822f715dcd8563a83fdc66dd3177ba9" alt="image.png"
data:image/s3,"s3://crabby-images/8f7bc/8f7bc1caa093005ee31cfcba57da2d6b42d82901" alt="image.png"
data:image/s3,"s3://crabby-images/3ff64/3ff64315261ca6e24b8be2e189886e815001d179" alt="image.png"
6. メッセージのPublish/Subscribeのテスト
Kafka producerとKafka comsumerのコンテナをメッセージの出し入れを確認します。
・Kafkaクラスタと同一Project(namespace)にて実行します。
・Kafkaクラスタのbootstrapサービス名を確認します。
$ oc project
Using project "amqstreams" on server "https://xxxxx.containers.cloud.ibm.com:xxxxx".
$ oc get svc
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
my-cluster-kafka-bootstrap ClusterIP 172.21.163.220 <none> 9091/TCP,9092/TCP,9093/TCP 12h
my-cluster-kafka-brokers ClusterIP None <none> 9091/TCP,9092/TCP,9093/TCP 12h
my-cluster-zookeeper-client ClusterIP 172.21.230.221 <none> 2181/TCP 12h
my-cluster-zookeeper-nodes ClusterIP None <none> 2181/TCP,2888/TCP,3888/TCP 12h
・Kafka producerをデプロイし、kafka-console-producer.shを実行し、プロンプトに任意のメッセージを入れます。
$ oc run kafka-producer -ti --image=registry.redhat.io/amq7/amq-streams-kafka-26-rhel7:1.6.0 --rm=true --restart=Never -- bin/kafka-console-producer.sh --broker-list my-cluster-kafka-bootstrap:9092 --topic my-topic
If you don't see a command prompt, try pressing enter.
>hello001
>hello002
>hello003
>hello004
>^Cpod "kafka-producer" deleted
pod amqstreams/kafka-producer terminated (Error)
・メッセージを確認するため、次にKafka consumerをデプロイし、kafka-console-consumer.shを実行します。
$ oc run kafka-consumer -ti --image=registry.redhat.io/amq7/amq-streams-kafka-26-rhel7:1.6.0 --rm=true --restart=Never -- bin/kafka-console-consumer.sh --bootstrap-server my-cluster-kafka-bootstrap:9092 --topic my-topic --from-beginning
If you don't see a command prompt, try pressing enter.
hello001
hello002
hello004
hello003
・メッセージが確認できました!
導入確認はここまでにして、次回はKafkaのメトリクス取得を行いたいと思います。
参考文献:
1.Using AMQ Streams on OpenShift
2.Chapter 4. Deploying AMQ Streams
3.Chapter 5. Setting up client access to the Kafka cluster
4.OpenShift + AMQ Streams(Apache Kafka) + QUARKUS で実現するアプリケーション