0


Docker Compose部署Kafka(非Zookeeper​)

整个工具的代码都在Gitee或者Github地址内

gitee:solomon-parent: 这个项目主要是总结了工作上遇到的问题以及学习一些框架用于整合例如:rabbitMq、reids、Mqtt、S3协议的文件服务器、mongodb

github:GitHub - ZeroNing/solomon-parent: 这个项目主要是总结了工作上遇到的问题以及学习一些框架用于整合例如:rabbitMq、reids、Mqtt、S3协议的文件服务器、mongodb

1.新增data文件夹

2.新增logs文件夹

3.新增docker-compose.yml文件

  1. version: '3.8'
  2. services:
  3. kafka:
  4. image: apache/kafka:latest # 使用支持 Kraft 模式的 Kafka 版本
  5. container_name: kafka
  6. ports:
  7. - "9092:9092" # 将 Kafka 的默认端口映射到主机
  8. environment:
  9. KAFKA_KRAFT_MODE: "true" # 启用 Kraft 模式以取代 Zookeeper
  10. KAFKA_PROCESS_ROLES: "broker,controller" # 定义 Kafka 的角色为 broker 和 controller
  11. KAFKA_NODE_ID: 1 # Kafka 节点的唯一 ID
  12. KAFKA_LISTENERS: "PLAINTEXT://:9092,CONTROLLER://:29092" # 配置 Kafka 的监听接口
  13. KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: "PLAINTEXT:PLAINTEXT,CONTROLLER:PLAINTEXT" # 定义监听器的协议映射
  14. KAFKA_INTER_BROKER_LISTENER_NAME: "PLAINTEXT" # 用于 broker 之间通信的监听器名称
  15. KAFKA_CONTROLLER_LISTENER_NAMES: "CONTROLLER" # 定义控制器使用的监听器名称
  16. KAFKA_CONTROLLER_QUORUM_VOTERS: "1@localhost:29092" # 配置控制器投票者
  17. KAFKA_LOG_DIRS: "/var/lib/kafka/data" # 数据文件存储目录
  18. KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1 # 设置偏移量主题的复制因子
  19. KAFKA_TRANSACTION_STATE_LOG_REPLICATION_FACTOR: 1 # 定义事务状态日志的复制因子
  20. KAFKA_TRANSACTION_STATE_LOG_MIN_ISR: 1 # 事务日志的最小同步副本
  21. KAFKA_MIN_INSYNC_REPLICAS: 1 # 最小同步副本数
  22. KAFKA_BROKER_ID: 1 # Broker 的唯一 ID
  23. KAFKA_LOG4J_LOGGERS: "kafka.controller=INFO,state.change.logger=INFO" # 定义特定日志类别的日志级别
  24. volumes:
  25. - ./data/kafka:/var/lib/kafka/data # 持久化 Kafka 数据到本地目录
  26. - ./logs/kafka:/var/log/kafka # 将 Kafka 容器的日志输出到本地主机目录
标签: docker kafka 容器

本文转载自: https://blog.csdn.net/m0_38040684/article/details/143735036
版权归原作者 想学习java初学者 所有, 如有侵权,请联系我们删除。

“Docker Compose部署Kafka(非Zookeeper​)”的评论:

还没有评论