使用docker单机部署kafka,以KRaft模式运行,不使用zookeeper,

  1. 如果是私有化部署,且不能访问公网的情况下,需要自己安装confluentinc/cp-kafka:latest镜像;

  2. 创建docker-compose.yaml文件

    yaml 复制代码
    services:
      kafka:
        image: confluentinc/cp-kafka:latest
        container_name: kafka
        hostname: kafka
        user: root  # 以 root 用户运行
        # 使用主机网络模式,这样容器直接使用宿主机的网络
        network_mode: "host"
        # 注意:在host模式下,端口映射无效,所以移除ports配置
        environment:
          KAFKA_NODE_ID: 1
          KAFKA_PROCESS_ROLES: 'broker,controller'
          # 监听所有网络接口
          KAFKA_LISTENERS: 'PLAINTEXT://0.0.0.0:9092,CONTROLLER://0.0.0.0:29093'
          # 使用宿主机IP作为广告地址
          KAFKA_ADVERTISED_LISTENERS: 'PLAINTEXT://192.168.0.91:9092'
          KAFKA_CONTROLLER_QUORUM_VOTERS: '1@192.168.0.91:29093'
          KAFKA_CONTROLLER_LISTENER_NAMES: 'CONTROLLER'
          KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: 'CONTROLLER:PLAINTEXT,PLAINTEXT:PLAINTEXT'
          KAFKA_INTER_BROKER_LISTENER_NAME: 'PLAINTEXT'
          KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
          KAFKA_GROUP_INITIAL_REBALANCE_DELAY_MS: 0
          KAFKA_TRANSACTION_STATE_LOG_MIN_ISR: 1
          KAFKA_TRANSACTION_STATE_LOG_REPLICATION_FACTOR: 1
          KAFKA_CLUSTER_ID: 'MkU3OEVBNTcwNTJENDM2Qk'
          LOG4J_LOGGER_KAFKA: INFO
          LOG4J_LOGGER_ORG_APACHE_KAFKA: INFO
          KAFKA_ZOOKEEPER_CONNECT: ''
        volumes:
          - ./kafka-data:/var/lib/kafka/data
          - ./logs:/var/log/kafka
        restart: unless-stopped
        # 在host模式下,不需要指定networks
  3. 将docker-compose.yaml拷贝到服务器上,运行启动命令

    bash 复制代码
    docker compose up -d
  4. 启动成功后,进行验证

    1. 创建 Topic

    bash 复制代码
    docker exec -it kafka kafka-topics --create --topic test-topic --bootstrap-server localhost:9092 --partitions 1 --replication-factor 1

    2. 开启生产者(发送消息)

    运行下面命令后,输入一些文字并回车:

    bash 复制代码
    docker exec -it kafka kafka-console-producer --topic test-topic --bootstrap-server localhost:9092

    3. 开启消费者(接收消息)

    打开另一个终端窗口执行,看是否能收到刚才输入的文字:

    bash 复制代码
    docker exec -it kafka kafka-console-consumer --topic test-topic --from-beginning --bootstrap-server localhost:9092
  5. 如果失败可以使用如下命令查看错误日志,排查问题

    bash 复制代码
    docker logs kafka # 对应docker-compose.yaml文件中的container_name
相关推荐
lichenyang4531 天前
Docker 学习笔记(五):Docker Compose,用一个 YAML 启动前端、后端和 MongoDB
docker
lichenyang4531 天前
Docker 学习笔记(四):Dockerfile,把项目打成自己的镜像
docker·容器
lichenyang4531 天前
Docker 学习笔记(三):Docker 网络、bridge、子网和容器互通
docker·容器
lichenyang4531 天前
Docker 学习笔记(二):docker run 的参数到底在控制什么?
docker·容器
阿里云云原生2 天前
数据链路再精简:Kafka 如何做到“零 ETL”一键写入 Apache Iceberg?
kafka
Patrick_Wilson6 天前
从「改个端口」到 502:Next.js on k8s 的容器端口、Service 映射与 env 覆盖
docker·kubernetes·next.js
Suroy6 天前
DockerView-Go:用 Go 写一个终端 Docker 监控工具,顺便做了个 Web 仪表盘
docker
云恒要逆袭7 天前
运行你的第一个Docker容器
后端·docker·容器
宋均浩7 天前
# Docker 镜像瘦身实战:从 1.2G 到 80MB 的五个优化步骤
ci/cd·docker
程序员老赵8 天前
10 分钟部署 OpenCode:Docker 一键安装,浏览器打开就能用 AI 写代码(附完整命令与排错)
docker·容器·ai编程