【Docker基础六】docker-compose安装zookeeper、kafka、kafdrop

本文使用 Bitnami/Kafka 提供的kafka容器镜像。详情参考:bitnami/kafka - Docker 镜像 |Docker 中心

创建Docker Compose文件

创建一个名为 docker-compose.yml 的文件,并复制以下内容

javascript 复制代码
version: "3.8"
services:
  zookeeper:
    image: docker.io/bitnami/zookeeper:3.9
    container_name: zookeeper
    restart: always
    ports:
      - "2181:2181"
    volumes:
      - "zookeeper_data:/usr/local/software/data/zookeeper"
    environment:
      - ALLOW_ANONYMOUS_LOGIN=yes
    networks:
      - m-kafka-network

  kafka:
    image: docker.io/bitnami/kafka:3.4
    container_name: kafka
    restart: always
    ports:
      - "9092:9092"
    volumes:
      - "kafka_data:/usr/local/software/data/kafka"
    environment:
      - KAFKA_BROKER_ID=1
      - ALLOW_PLAINTEXT_LISTENER=yes 
      - KAFKA_CFG_ZOOKEEPER_CONNECT=zookeeper:2181
      - KAFKA_CFG_LISTENER_SECURITY_PROTOCOL_MAP=PLAINTEXT:PLAINTEXT
      - KAFKA_CFG_LISTENERS=PLAINTEXT://0.0.0.0:9092
      - KAFKA_CFG_ADVERTISED_LISTENERS=PLAINTEXT://127.0.0.1:9092
    networks:
      - m-kafka-network
    depends_on:
      - zookeeper

  kafdrop:
    image: obsidiandynamics/kafdrop
    container_name: kafdrop
    restart: always
    ports:
      - "9000:9000"
    environment:
      KAFKA_BROKERCONNECT: "kafka:9092"
    networks:
      - m-kafka-network
    depends_on:
      - kafka

volumes:
  kafka_data:
    driver: local
  zookeeper_data:
    driver: local

networks:
  m-kafka-network:

部分参数解释:

1、KAFKA_CFG_LISTENERS:

设置为 PLAINTEXT://0.0.0.0:9092 允许 Kafka 从任何 IP 地址接受连接。

2、ALLOW_PLAINTEXT_LISTENER=yes

这个参数允许 Kafka 接受未加密的连接,即使用 PLAINTEXT 协议的连接。这对于测试环境很有用,但在生产环境中,通常建议使用加密的连接(如 SSL/TLS)来保证数据安全。

验证配置:

javascript 复制代码
docker-compose -f docker-compose.yml config

启动服务

执行命令

javascript 复制代码
docker-compose up -d

执行结果

查看是否启动

javascript 复制代码
docker-compose ps

执行结果

如果服务未启动,可以执行下面命令查看日志

javascript 复制代码
docker-compose logs

验证服务

浏览器访问 kafdrop 服务地址:127.0.0.1:9000 ,并创建一个Topic。

停止服务

执行命令

javascript 复制代码
docker-compose stop

如果想停止并删除所有由 docker-compose.yml 定义的容器,网络和其他资源,执行

javascript 复制代码
docker-compose down
相关推荐
天上掉下来个程小白6 小时前
Docker-14.项目部署-DockerCompose
运维·docker·微服务·容器
星霜笔记9 小时前
Docker 部署 MariaDB+phpMyAdmin+Nextcloud 完整教程
运维·数据库·docker·容器·mariadb
数据知道12 小时前
容器化部署:用Docker封装机器翻译模型与服务详解
docker·容器·机器翻译
敲上瘾18 小时前
Linux系统cgroups资源精细化控制基础
linux·测试工具·docker·压力测试·cgroups
伊成21 小时前
Docker 部署 Nginx 完整指南
nginx·docker·容器
落日漫游21 小时前
K8s核心组件全解析
运维·docker·运维开发
江湖有缘1 天前
【Docker项目实战】使用Docker部署Notepad轻量级记事本
docker·容器·notepad++
yh云想1 天前
《从入门到精通:Kafka核心原理全解析》
分布式·kafka
武子康1 天前
大数据-70 Kafka 日志清理:删除、压缩及混合模式最佳实践
大数据·后端·kafka
BTU_YC1 天前
docker compose部署mysql
mysql·adb·docker