Apache Kafka Docker容器外连接踩坑一则

第一次接触 Kafka,想要写个 Demo 测试一下,就用 Docker 直接在本地部署了一个,测试的时候踩了个坑:默认配置下从容器外没法连接到容器内部。记录一下解决过程。

部署和配置

使用的是镜像是 bitnami/kafka:latest,运行容器的命令如下:

shellscript 复制代码
docker run -d --name kafka \
    --network kafka \
    -v kafka:/bitnami/kafka \
    -p 9092:9092 \
    -e TZ=Asia/Shanghai \
    -e ALLOW_PLAINTEXT_LISTENER=yes \
    -e KAFKA_CFG_AUTO_CREATE_TOPICS_ENABLE=true \
    bitnami/kafka:latest

同时我还用 provectuslabs/kafka-ui:latest 镜像部署了一个 Kafka UI 用来可视化管理,接入了 kafka 容器网络。

org.springframework.kafka:spring-kafka 集成到 Spring Boot 中,连接配置如下:

yaml 复制代码
spring:
  kafka:
    bootstrap-servers:
      - "localhost:9092"

运行和排错

在 kafka-ui 中确认连接成功后,我尝试在其中连接 Kafka 节点,连接成功。

然后 bootRun ------ 运行报错: 看到连接错误,我首先想到是不是 Kafka 本身没有拉起来,于是我在面板中尝试收发消息,全部成功了。

看到日志中的 UnknownHostException: ec79ba9450e3,于是我猜和容器有关系。已知 Docker 本身应该没什么问题,于是去 Docker Hub 上仔细阅读了一下 bitnami/kafka 镜像的 Overview,发现了: 我查了一下 Kafka 的文档,大概是:需要通过配置 advertised.listeners 来告知客户端需要连接的 Kafka 地址,否则客户端就会像我上面一样试图去连接 ec79ba9450e3:9092 这个地址,而 ec79ba9450e3 这个主机名在宿主机中当然是未知的主机名,所以就会导致连接异常。

解决方案

如上文中镜像 Overview 中所写的一样,添加如下的三条环境变量:

ruby 复制代码
KAFKA_CFG_LISTENERS=PLAINTEXT://:9092,CONTROLLER://:9093,EXTERNAL://:9094
KAFKA_CFG_ADVERTISED_LISTENERS=PLAINTEXT://kafka:9092,EXTERNAL://localhost:9094
KAFKA_CFG_LISTENER_SECURITY_PROTOCOL_MAP=CONTROLLER:PLAINTEXT,EXTERNAL:PLAINTEXT,PLAINTEXT:PLAINTEXT

然后暴露容器端口9094,将应用的 spring.kafka.bootstrap-servers 一项从 "localhost:9092" 改为 "localhost:9094" ,连接成功!

后记

由于我的应用本身实际上也是跑在容器里的,所以只需要像上面的 kafka-ui 一样和 Kafka 组到同一个 Docker 网络里就行了,以上配置实际上是不需要的,Docker 部署的情况下只有需要容器外连接 Kafka 才需要配置这些。


如果上文中有任何地方写的有问题的话欢迎指出,如果觉得有用的话还请点个赞!QwQ

相关推荐
indexsunny14 小时前
互联网大厂Java面试实战:Spring Boot微服务在电商场景中的应用与挑战
java·spring boot·redis·微服务·kafka·spring security·电商
TTBIGDATA14 小时前
【Atlas】Ambari 中 开启 Kerberos + Ranger 后 Atlas Hook 无权限访问 Kafka Topic:ATLAS_HOOK
大数据·kafka·ambari·linq·ranger·knox·bigtop
岁岁种桃花儿18 小时前
Kafka从入门到上天系列第一篇:kafka的安装和启动
大数据·中间件·kafka
TTBIGDATA2 天前
【Atlas】Atlas Hook 消费 Kafka 报错:GroupAuthorizationException
hadoop·分布式·kafka·ambari·hdp·linq·ranger
indexsunny2 天前
互联网大厂Java面试实战:微服务与Spring生态技术解析
java·spring boot·redis·kafka·mybatis·hibernate·microservices
编程彩机2 天前
互联网大厂Java面试:从Spring Boot到分布式事务的技术场景解析
spring boot·kafka·分布式事务·微服务架构·java面试·技术解析
没有bug.的程序员2 天前
RocketMQ 与 Kafka 深度对垒:分布式消息引擎内核、事务金融级实战与高可用演进指南
java·分布式·kafka·rocketmq·分布式消息·引擎内核·事务金融
yumgpkpm2 天前
华为昇腾300T A2训练、微调Qwen过程,带保姆式命令,麒麟操作系统+鲲鹏CPU
hive·hadoop·华为·flink·spark·kafka·hbase
ApachePulsar2 天前
演讲回顾|谙流科技在 Kafka on Pulsar 之上的探索
分布式·科技·kafka
yumgpkpm3 天前
2026软件:白嫖,开源,外包,招标,晚进场(2025年下半年),数科,AI...中国的企业软件产业出路
大数据·人工智能·hadoop·算法·kafka·开源·cloudera