ToB企服应用市场:ToB评测及商务社交产业平台

标题: Kafka内外网分流设置listeners和advertised.listeners [打印本页]

作者: 十念    时间: 2024-8-31 23:05
标题: Kafka内外网分流设置listeners和advertised.listeners
问题背景:

Kafka部署在内网,内网Java服务会利用Kafka收发消息,别的,Java服务会与其他第三方体系利用kafka实现数据同步,也就是外网也会发送消息到kafka,外网IP做了端口映射到了内网,advertised.listeners设置了外网ip端口,所以这里的问题就是内网步伐发送kafka消息也会走到外网,如许会有部门毗连出现超时错误,所以这种方式不太合理。
解决办法:

参考网上内外网分流方式进行处理,外部访问kafka通过公网毗连,内部步伐利用内网访问。
listeners与advertised.listeners含义

1. listeners

含义:用于指定Kafka Broker实际监听的地点和端口,listeners 的格式通常是:协议名称://主机名或IP地点:端口,可以同时设置多个, 而且用逗号隔开,监听器的名称和端口必须是唯一的,端口相同,就冲突了。
示例
  1. listeners=PLAINTEXT://your.host.name:9092
复制代码
在这个示例中,Kafka Broker将监听your.host.name这个主机名上的9092端口,并利用PLAINTEXT协议(即不加密的文本协议)。
2.advertised.listeners

含义
Kafka 服务器对外宣传的端点信息,它会将地点注册到Zookeeper中,用于告诉客户端应该毗连到哪个地点和端口,也就是客户端真正要访问的地点。advertised.listeners 的格式与 listeners 类似,但是可以指定差别的地点或端口,如果没有设置,则默认值和listener一样,别的,advertised.listeners不支持0.0.0.0这种情势, 所以如果listeners属性设置成0.0.0.0,则必须设置advertised.listeners属性。
示例
  1. listeners=PLAINTEXT://internal.host.name:9092  
  2. advertised.listeners=PLAINTEXT://external.host.name:9092
复制代码
在这个示例中,Kafka Broker在内部网络上监听internal.host.name这个主机名上的9092端口,但向外部客户端公布external.host.name这个主机名上的9092端口作为毗连地点。
内外网分流设置修改

kakfa设置文件config/server.properties修改前
  1. listeners=PLAINTEXT://172.20.0.147:9092
  2. advertised.listeners=PLAINTEXT://10.103.25.230:9092
复制代码
修改后
  1. listeners=INSIDE://:19092,OUTSIDE://:9092
  2. advertised.listeners=INSIDE://172.20.0.147:19092,OUTSIDE://10.103.25.230:9092
  3. listener.security.protocol.map=INSIDE:PLAINTEXT,OUTSIDE:PLAINTEXT
  4. inter.broker.listener.name=INSIDE
复制代码
说明

碰到问题

  1. org.apache.kafka.common.KafkaException: Socket server failed to bind to 10.103.25.230:9092: Cannot assign requested address.
复制代码
解决方案
将listeners由原来固定IP修改为:
  1. listeners=INSIDE://:19092,OUTSIDE://:9092
复制代码
参考链接:
https://juejin.cn/post/6893410969611927566
https://www.confluent.io/blog/kafka-listeners-explained/

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4