docker-compose搭建kafka集群

docker-compose文件

注意替换ip

version: '3'
networks:
  docker_network:
    external: true
services:
  zookeeper:
    image: wurstmeister/zookeeper
    networks:
      - docker_network
    container_name: zookeeper
    ports:
      - 2181:2181
    environment:
      - TZ=Asia/Shanghai

  kafka:
    image: wurstmeister/kafka
    networks:
      - docker_network
    container_name: kafka00
    ports:
      - 9090:9090
    environment:
      - TZ=Asia/Shanghai
      - KAFKA_BROKER_ID=0
      - KAFKA_ZOOKEEPER_CONNECT=zookeeper容器ip:2181
      - KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://服务器ip:9090
      - KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9090
  
  kafka1:
    image: wurstmeister/kafka
    networks:
      - docker_network
    container_name: kafka01
    ports:
      - 9091:9091
    environment:
      - TZ=Asia/Shanghai
      - KAFKA_BROKER_ID=1
      - KAFKA_ZOOKEEPER_CONNECT=zookeeper容器ip:2181
      - KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://服务器ip:9091
      - KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9091
  kafka2:
    image: wurstmeister/kafka
    networks:
      - docker_network
    container_name: kafka02
    ports:
      - 9092:9092
    environment:
      - TZ=Asia/Shanghai
      - KAFKA_BROKER_ID=2
      - KAFKA_ZOOKEEPER_CONNECT=zookeeper容器ip:2181
      - KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://服务器ip:9092
      - KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9092

启动

zk:docker-compose up -d zookeeper
kafka00:docker-compose up -d kafka
kafka01:docker-compose up -d kafka1
kafka02:docker-compose up -d kafka2

创建一个测试主题

进入kafka00容器 docker exec -it kafka00 bash
创建一个主题
/opt/kafka/bin/kafka-topics.sh --create --zookeeper zk容器ip:2181 --replication-factor 3 --partitions 5 --topic TestTopic

查看主题情况

建议在打开两个ssh连接的窗口 (自行进入)
查看主题
/opt/kafka/bin/kafka-topics.sh --describe --zookeeper zk容器ip:2181 --topic TestTopic
在这里插入图片描述
其他的几个容器也应该是一样的。。。省略

发送消息测试

记得放开9090、9091、9092端口
接下来,分别在kafka00上运行一个生产者,kafka01、02上分别运行一个消费者:
生产者:

/opt/kafka/bin/kafka-console-producer.sh --broker-list 服务器ip:当前kafka端口(9090) --topic TestTopic

消费者 (分别在kafka01,kafka02)

kafka01:
/opt/kafka/bin/kafka-console-consumer.sh --bootstrap-server 服务器ip:当前kafka端口(9091) --topic TestTopic --from-beginning

kafka02:
/opt/kafka/bin/kafka-console-consumer.sh --bootstrap-server 服务器ip:当前kafka端口(9092) --topic TestTopic --from-beginning

然后在生产者发消息:
在这里插入图片描述

看两个消费者是否都能接收
在这里插入图片描述
在这里插入图片描述
至此,结束

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值