Mac上使用Docker搭建kafka集群方式
1、拉取鏡像
// 拉取 kafka 鏡像 docker pull wurstmeister/kafka // 拉取 zookeeper 鏡像 docker pull zookeeper

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

3、運(yùn)行kafka
注意:192.168.124.11 為宿主機(jī)IP
Kafka0:
docker run -d --name kafka0 -p 9092:9092 -e KAFKA_BROKER_ID=0 -e KAFKA_ZOOKEEPER_CONNECT=192.168.124.11:2181 -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://192.168.124.11: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.124.11:2181 -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://192.168.124.11: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.124.11:2181 -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://192.168.124.11:9094 -e KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9094 -t wurstmeister/kafka

參數(shù)說明:
- -e KAFKA_BROKER_ID=0 在kafka集群中,每個(gè)kafka都有一個(gè)BROKER_ID來區(qū)分自己
- -e KAFKA_ZOOKEEPER_CONNECT=192.168.124.11:2181/kafka 配置zookeeper管理kafka的路徑192.168.124.11:2181/kafka
- -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://192.168.124.11:9092 把kafka的地址端口注冊(cè)給zookeeper,如果是遠(yuǎn)程訪問要改成外網(wǎng)IP。
- -e KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9092 配置kafka的監(jiān)聽端口:這個(gè)不能改-v /etc/localtime:/etc/localtime 容器時(shí)間同步虛擬機(jī)的時(shí)間
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.124.11:2181 --replication-factor 3 --partitions 5 --topic TestTopic
查看topic:
// 查看指定 topic kafka-topics.sh --zookeeper 192.168.124.11:2181 --topic TestTopic --describe // 查看 topic 集合 kafka-topics.sh --zookeeper 192.168.124.11:2181 --list
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)說明:
- Topic: TestTopic PartitionCount: 5 ReplicationFactor:3 代表TestTopic有5個(gè)分區(qū),3個(gè)副本節(jié)點(diǎn);
- Topic: 代表主題名稱
- 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.124.11:9092 --topic TestTopic kafka-console-consumer.sh --bootstrap-server 192.168.124.11:9093 --topic TestTopic --from-beginning kafka-console-consumer.sh --bootstrap-server 192.168.124.11:9094 --topic TestTopic --from-beginning

總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Alpine鏡像中telnet轉(zhuǎn)移至busybox-extras
今天小編就為大家分享一篇關(guān)于Alpine鏡像中telnet轉(zhuǎn)移至busybox-extras,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2018-12-12
查看docker中運(yùn)行的JVM參數(shù)問題及解決方法
這篇文章主要介紹了查看docker中運(yùn)行的JVM參數(shù),方法一使用的是jcmd命令,方法二是jinfo命令,本文給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧2022-04-04
在Centos7中安裝Docker1.12的詳細(xì)教程
本篇文章主要介紹了在Centos7中安裝Docker1.12的詳細(xì)教程。具有一定的參考價(jià)值,有興趣的可以了解一下。2017-02-02
docker修改容器內(nèi)存大小的實(shí)現(xiàn)方式
我們使用docker時(shí),經(jīng)常會(huì)遇到docker容器使用內(nèi)存大于docker宿主機(jī)內(nèi)存,導(dǎo)致宿主機(jī)奔潰,從而影響其他宿主機(jī)上容器的運(yùn)行,下面這篇文章主要給大家介紹了關(guān)于docker修改容器內(nèi)存大小的相關(guān)資料,需要的朋友可以參考下2022-09-09
Docker從零開始學(xué)習(xí)之Commit提交命令
docker commit命令是用于根據(jù)docker容器的改變創(chuàng)建一個(gè)新的docker鏡像,下面這篇文章主要給大家介紹了關(guān)于Docker從零開始學(xué)習(xí)之Commit提交命令的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-05-05
Windows Docker 部署 SolrCloud的方法步驟
本文主要介紹了Windows Docker 部署 SolrCloud的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-10-10

