本文主要是介绍如何在一台服务器上使用docker运行kafka集群,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
《如何在一台服务器上使用docker运行kafka集群》文章详细介绍了如何在一台服务器上使用Docker运行Kafka集群,包括拉取镜像、创建网络、启动Kafka容器、检查运行状态、编写启动和关闭脚本...
1.拉取镜像
docker pull wurstmeister/kafka
docker pull wurstmeister/zookeeper
2.创建集群之间通信的网络
docker network create kafka-cluster-net
docker network inspect kafka-cluster-net
3.将zookeeper加入到网络中
docker network connect kafka-cluster-net zookeeper
4.启动kafka集群
docker run -d \
--name kafka-0 \
--network kafka-cluster-net \
-p 9092:9092 \
-e KAFKA_BRandroidOKER_ID=0 \
-e KAFKA_ZOOKEEPER_CONNECT=zookeeper:2181 \
-e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://localhost:9092 \
-e KAFKA_LISTENERS=PLAINTEXT://:9092 \
wurstmeister/kafka
- 首先创建一个自定义网络,方便容器间通信:
- 运行第一个 Kafka 容器:
- --name kafka-0:给容器命名,这里以 kafka-0 表示第一个节点,后续可类推更改数字来创建不同节点。
- --network kafka-cluster-net:让容器接入刚才创建的自定义网络。
- -p 9092:9092:映射端口,使得外部能访问容器内的 Kafka 服务。
- KAFKA_BROKER_ID:指定 broker 的唯一 ID,每个节点不能相同。
- KAFKA_ZOOKEEPER_CONNECT:指向刚才启动的 Zookeeper 容器名称及端口,容器间通过名称可互相访问。
- KAFKA_ADVERTISED_LISTENERS:对外暴露的连接地址,这里使用 localhost,根据实际情况修改。
- KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR:副本因子,这里设置为 1http://www.chinasem.cn,可按需调整。
- 运行第二个 Kafka 容器(类似地修改 broker ID 等参数):
- 按照上述方法可运行更多的 Kafka 容器来构建更大的集群,只需修改相应的 ID 和端口等参China编程数。
docker run -d \ --name kafka-1 \ --network kafka-cluster-net \ -p 9093:9092 \ -e KAFKA_BROKER_ID=1 \ -e KAFKA_ZOOKEEPER_CONNECT=zookeeper:2181 \ -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://localhost:9093 \ -e KAFKA_LISTENERS=PLAINTEXT://:9092 \ wurstmeister/kafka
5.检查是否运行
docker ps
docker network inspect kafka-cluster-net
检查网络以及容器运行状态
6.编写集群启动脚本
start_kafka_cluster.sh :
#!/bin/bash docker start zookeeper sleep 4 docker start kafka-0 kafka-1 echo "Kafka cluster containers started successfully."
7.编写集群关闭脚本
stop_kafka_cluster.sh:
#!/bin/bash docker stop kafka-0 kafka-1 zookeeper echo "Kafka cluster containers stopped successfully."
8.进入容器检查
docker exec -it kafka-0 /bin/bash
cd /opt/kafka/ &njavascriptbsp; #切换到内部kafka目录
9.故障排查
如果在使用Docker过程中遇到任何错误, 可以命令:
docker logs 容器ID/容器名称
10、启动生产者
./kafka-console-producer.sh --broker-list localhost:9092 --topic [你的topic名称]
11.启动消费者
为了看到生产者和消费者之间的消息传递效果,这里需要另开一个终端,按照上面的方法进入容器对应目录,并执行以下命令:
./kKGRNYoafka-console-consumer.sh --bootstrap-server [你的IP地址]:9092 --topic [你的topic名称]
到此这篇关于在一台服务器上使用docker运行kafka集群的文章就介绍到这了,更多相关docker运行kafka集群内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程China编程(www.chinasem.cn)!
这篇关于如何在一台服务器上使用docker运行kafka集群的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!