Docker容器搭建Kafka集群的詳細過程
一、Kafka集群的搭建
1.拉取相關(guān)鏡像
docker pull wurstmeister/kafka docker pull zookeeper
2.運行zookeeper
docker run -d --name zookeeper -p 2181:2181 -t zookeeper
3.運行kafka
Kafka0:
docker run -d --name kafka0 -p 9092:9092 -e KAFKA_BROKER_ID=0 -e KAFKA_ZOOKEEPER_CONNECT=192.168.16.129:2181 -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://192.168.16.129:9092 -e KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9092 -t wurstmeister/kafka
Kafka1:
docker run -d --name kafka1 -p 9093:9093 -e KAFKA_BROKER_ID=1 -e KAFKA_ZOOKEEPER_CONNECT=192.168.16.129:2181 -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://192.168.16.129:9093 -e KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9093 -t wurstmeister/kafka
Kafka2:
docker run -d --name kafka2 -p 9094:9094 -e KAFKA_BROKER_ID=2 -e KAFKA_ZOOKEEPER_CONNECT=192.168.16.129:2181 -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://192.168.16.129:9094 -e KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9094 -t wurstmeister/kafka
參數(shù)說明:
-e KAFKA_BROKER_ID=0
在kafka集群中,每個kafka都有一個BROKER_ID來區(qū)分自己-e KAFKA_ZOOKEEPER_CONNECT=10.20.8.50:2181/kafka
配置zookeeper管理kafka的路徑10.20.8.50:2181/kafka-e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://10.20.8.50:9092
把kafka的地址端口注冊給zookeeper,如果是遠程訪問要改成外網(wǎng)IP。-e KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9092
配置kafka的監(jiān)聽端口:這個不能改-v /etc/localtime:/etc/localtime
容器時間同步虛擬機的時間
啟動3個Kafka節(jié)點
4.設(shè)置topic
進入kafka0
docker exec -it kafka0 /bin/bash
進入bin目錄
cd /opt/kafka_2.13-2.8.1/bin
創(chuàng)建topic
kafka-topics.sh --create --zookeeper 192.168.16.129:2181 --replication-factor 3 --partitions 5 --topic TestTopic
查看topic
kafka-topics.sh --describe --zookeeper 192.168.16.129:2181 --topic TestTopic
Kafka的topic所有分區(qū)會分散在不同Broker上,所以該topic的5個分區(qū)會被分散到3個Broker上,其中有兩個Broker得到兩個分區(qū),另一個Broker只有1個分區(qū),如圖所示:
集群節(jié)點說明:
Topic: TestTopic PartitionCount: 5 ReplicationFactor:3
代表TestTopic有5個分區(qū),3個副本節(jié)點;Topic
: 代表主題名稱Leader
代表主題節(jié)點號,Replicas
代表他的副本節(jié)點有Broker.id = 2、0、1(包括Leader Replica和Follower Replica,且不管是否存活),Isr
表示存活并且同步Leader節(jié)點的副本有Broker.id = 2、0、1
5.進行生產(chǎn)者和消費者測試
分別在Broker0上運行一個生產(chǎn)者,Broker1、2上分別運行一個消費者:
kafka-console-producer.sh --broker-list 192.168.16.129:9092 --topic TestTopic kafka-console-consumer.sh --bootstrap-server 192.168.16.129:9093 --topic TestTopic --from-beginning kafka-console-consumer.sh --bootstrap-server 192.168.16.129:9094 --topic TestTopic --from-beginning
到此這篇關(guān)于Docker容器 Kafka集群的搭建的文章就介紹到這了,更多相關(guān)Docker搭建Kafka集群內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
docker-compose部署配置jenkins的詳細教程
這篇文章主要介紹了docker-compose部署配置jenkins的詳細教程,本文通過示例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07Docker部署UI自動化測試環(huán)境的實現(xiàn)步驟
本文主要介紹了Docker部署UI自動化測試環(huán)境的實現(xiàn)步驟,通過Docker可以快速創(chuàng)建、部署和測試腳本,提高測試效率,具有一定的參考價值,感興趣的可以了解一下2023-08-08MySQL容器中docker-entrypoint-initdb.d目錄的使用
這篇文章主要介紹了MySQL容器中docker-entrypoint-initdb.d目錄的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05