Docker容器搭建Kafka集群的詳細(xì)過(guò)程
一、Kafka集群的搭建
1.拉取相關(guān)鏡像
docker pull wurstmeister/kafka docker pull zookeeper

2.運(yùn)行zookeeper
docker run -d --name zookeeper -p 2181:2181 -t zookeeper

3.運(yùn)行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ù)說(shuō)明:
-e KAFKA_BROKER_ID=0在kafka集群中,每個(gè)kafka都有一個(gè)BROKER_ID來(lái)區(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的地址端口注冊(cè)給zookeeper,如果是遠(yuǎn)程訪(fǎng)問(wèn)要改成外網(wǎng)IP。-e KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9092配置kafka的監(jiān)聽(tīng)端口:這個(gè)不能改-v /etc/localtime:/etc/localtime容器時(shí)間同步虛擬機(jī)的時(shí)間
啟動(dòng)3個(gè)Kafka節(jié)點(diǎn)

4.設(shè)置topic
進(jìn)入kafka0
docker exec -it kafka0 /bin/bash
進(jìn)入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ū)會(huì)分散在不同Broker上,所以該topic的5個(gè)分區(qū)會(huì)被分散到3個(gè)Broker上,其中有兩個(gè)Broker得到兩個(gè)分區(qū),另一個(gè)Broker只有1個(gè)分區(qū),如圖所示:

集群節(jié)點(diǎn)說(shuō)明:
Topic: TestTopic PartitionCount: 5 ReplicationFactor:3代表TestTopic有5個(gè)分區(qū),3個(gè)副本節(jié)點(diǎn);Topic: 代表主題名稱(chēng)Leader代表主題節(jié)點(diǎn)號(hào),Replicas代表他的副本節(jié)點(diǎn)有Broker.id = 2、0、1(包括Leader Replica和Follower Replica,且不管是否存活),Isr表示存活并且同步Leader節(jié)點(diǎn)的副本有Broker.id = 2、0、1
5.進(jìn)行生產(chǎn)者和消費(fèi)者測(cè)試
分別在Broker0上運(yùn)行一個(gè)生產(chǎn)者,Broker1、2上分別運(yùn)行一個(gè)消費(fèi)者:
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)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Docker搭建服務(wù)器監(jiān)控面板的實(shí)現(xiàn)示例
Docker服務(wù)器監(jiān)控面板是一種用于監(jiān)控容器運(yùn)行情況的工具,本文主要介紹了Docker搭建服務(wù)器監(jiān)控面板的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01
docker-compose部署Java應(yīng)用和相關(guān)依賴(lài)方式
介紹如何使用docker-compose一鍵部署Java應(yīng)用及依賴(lài),并實(shí)現(xiàn)MySQL數(shù)據(jù)庫(kù)的自動(dòng)初始化2024-10-10
解決docker push報(bào)錯(cuò)denied問(wèn)題
Docker Push權(quán)限錯(cuò)誤需先登錄私有倉(cāng)庫(kù),創(chuàng)建項(xiàng)目并打指定tag,若推送到Docker Hub個(gè)人倉(cāng)庫(kù),確保登錄信息正確,權(quán)限匹配即可完成推送2025-08-08
docker save鏡像時(shí)進(jìn)行g(shù)zip壓縮方式
文章介紹了三種Docker鏡像壓縮方法:管道壓縮(推薦,使用gzip/pigz,速度快)、xz壓縮(高壓縮比但慢)、及先保存再壓縮(不推薦,占空間),建議日常用管道gzip,傳輸用xz,避免直接保存未壓縮文件2025-08-08
docker 復(fù)制容器的項(xiàng)目實(shí)踐
本文主要介紹了docker 復(fù)制容器的項(xiàng)目實(shí)踐,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-11-11
Docker鏡像導(dǎo)出與導(dǎo)入與拷貝實(shí)例分析
在本篇文章里小編給大家整理的是關(guān)于Docker鏡像導(dǎo)出與導(dǎo)入與拷貝實(shí)例分析,有需要的朋友們可以參考下。2020-02-02
Docker與docker-compose中volume參數(shù)的使用方式
文章介紹了Docker中的數(shù)據(jù)卷Volume的概念及其在宿主機(jī)和容器之間的數(shù)據(jù)共享和持久化,它詳細(xì)說(shuō)明了兩種數(shù)據(jù)掛載方式:通過(guò)宿主機(jī)絕對(duì)路徑掛載和通過(guò)卷標(biāo)映射掛載,包括匿名掛載和具名掛載,同時(shí),文章還展示了如何通過(guò)docker命令查看數(shù)據(jù)卷的宿主機(jī)目錄2024-11-11

