-
如果是私有化部署,且不能访问公网的情况下,需要自己安装confluentinc/cp-kafka:latest镜像;
-
创建docker-compose.yaml文件
yamlservices: 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 -
将docker-compose.yaml拷贝到服务器上,运行启动命令
bashdocker compose up -d -
启动成功后,进行验证
1. 创建 Topic
bashdocker exec -it kafka kafka-topics --create --topic test-topic --bootstrap-server localhost:9092 --partitions 1 --replication-factor 12. 开启生产者(发送消息)
运行下面命令后,输入一些文字并回车:
bashdocker exec -it kafka kafka-console-producer --topic test-topic --bootstrap-server localhost:90923. 开启消费者(接收消息)
打开另一个终端窗口执行,看是否能收到刚才输入的文字:
bashdocker exec -it kafka kafka-console-consumer --topic test-topic --from-beginning --bootstrap-server localhost:9092 -
如果失败可以使用如下命令查看错误日志,排查问题
bashdocker logs kafka # 对应docker-compose.yaml文件中的container_name
使用docker单机部署kafka,以KRaft模式运行,不使用zookeeper,
Byte Beat2026-02-04 9:03
相关推荐
极客先躯16 小时前
高级java每日一道面试题-2026年02月02日-实战篇[Docker]-如何实现容器的持久化存储?梦想的颜色16 小时前
Kafka内核解密:架构拓扑、数据流转与生产消费模型的深度剖析My is 李豆17 小时前
CentOS 7 安装 Docker 完整教程(含 docker-compose 插件)极客先躯17 小时前
高级java每日一道面试题-2026年02月01日-实战篇[Docker]-Docker Volume 的生命周期管理是怎样的?洛水水18 小时前
消息队列与Kafka详解kong@react18 小时前
Rocky Linux 10.2 全面解析:企业级 CentOS 替代方案及保姆级docker安装某林21219 小时前
Isaac Sim 5.1.0 无头服务器部署与 RTX 显存段错误排障全记录m0_7381207219 小时前
Docker 环境下 Vulfocus 靶场搭建全流程(附镜像源问题解决方案)simeple20 小时前
记一次 Docker Compose 项目迁移:从 Windows Docker Desktop 迁移到 CentOS 服务器SLD_Allen20 小时前
Kafka分区与消费者的关系kafka分区和消费者线程的关系