本文就用Kafka 2.8.
有时我们会碰到网络是通畅的,但却连不上Kafka,特别是在多网卡环境或者云环境上很容易出现。这个其实和Kafka的监听配置有关系。本文介绍监听相关的配置。目前监听相关的参数主要有下面几个:
listeners
advertised.listeners
listener.security.protocol.map
inter.broker.listener.name
security.inter.broker.protocol
advertised.host.name
(历史遗留,已废弃,勿使用)advertised.port
(历史遗留,已废弃,勿使用)host.name
(历史遗留,已废弃,勿使用)
其中最重要的就是 listeners
和 advertised.listeners
:集群启动时监听listeners配置的地址,并将 advertised.listeners
配置的地址写到Zookeeper里面,作为集群元数据的一部分。我们可以将客户端(生产者/消费者)连接Kafka集群进行操作的过程分成2步:
- 通过
listeners
配置的连接信息(ip/host)连接到某个Broker(broker会定期获取并缓存zk中的元数据信息),获取元数据中 <