当前位置: 首页 > news >正文

天津网站设计制作公司潍坊市建设银行坊子支行网站

天津网站设计制作公司,潍坊市建设银行坊子支行网站,手机网站比例尺寸,账号权重查询问题背景: Kafka部署在内网,内网Java服务会使用Kafka收发消息,另外,Java服务会与其他第三方系统使用kafka实现数据同步,也就是外网也会发送消息到kafka,外网IP做了端口映射到了内网,advertised…

问题背景:

Kafka部署在内网,内网Java服务会使用Kafka收发消息,另外,Java服务会与其他第三方系统使用kafka实现数据同步,也就是外网也会发送消息到kafka,外网IP做了端口映射到了内网,advertised.listeners配置了外网ip端口,所以这里的问题就是内网程序发送kafka消息也会走到外网,这样会有部分连接出现超时错误,所以这种方式不太合理。

解决办法:

参考网上内外网分流方式进行处理,外部访问kafka通过公网连接,内部程序使用内网访问。

listeners与advertised.listeners含义

1. listeners

含义:用于指定Kafka Broker实际监听的地址和端口,listeners 的格式通常是:协议名称://主机名或IP地址:端口,可以同时配置多个, 并且用逗号隔开,监听器的名称和端口必须是唯一的,端口相同,就冲突了。
示例

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属性。
示例

listeners=PLAINTEXT://internal.host.name:9092  
advertised.listeners=PLAINTEXT://external.host.name:9092

在这个示例中,Kafka Broker在内部网络上监听internal.host.name这个主机名上的9092端口,但向外部客户端公布external.host.name这个主机名上的9092端口作为连接地址。

内外网分流配置修改

kakfa配置文件config/server.properties修改前

listeners=PLAINTEXT://172.20.0.147:9092
advertised.listeners=PLAINTEXT://10.103.25.230:9092

修改后

listeners=INSIDE://:19092,OUTSIDE://:9092
advertised.listeners=INSIDE://172.20.0.147:19092,OUTSIDE://10.103.25.230:9092
listener.security.protocol.map=INSIDE:PLAINTEXT,OUTSIDE:PLAINTEXT
inter.broker.listener.name=INSIDE

说明

  • listeners这里设置了2个监听器,监听了所有IP的两个端口,19092为内网kafka使用端口,9092为外部访问端口
  • 172.20.0.147是内网服务器IP地址,10.103.25.230为公网IP地址,端口已也添加了映射:10.103.25.230->172.20.0.147,这样我们当我们通过kafka客户端连接kafka时,kafka会从zookeeper中获取kafka元数据信息,这时候kafka客户端得到的就是advertised.listeners的信息,因为这里OUTSIDE配置的外网IP,当客户端通过10.103.25.230访问kafka时,请求就会被之前配置的映射进行转发,被转发到内网ip,从而完成对kafka的访问。
  • listener.security.protocol.map为监听器名称和安全协议之间的映射关系集合,PLAINTEXT表示明文
  • inter.broker.listener.name用于broker之间通信的listener名称,如果未设置,则listener名称由 security.inter.broker.protocol 定义(security.inter.broker.protocol默认值是PLAINTEXT)

遇到问题

  1. 修改过程中的报错:
org.apache.kafka.common.KafkaException: Socket server failed to bind to 10.103.25.230:9092: Cannot assign requested address.

解决方案
listeners由原来固定IP修改为:

listeners=INSIDE://:19092,OUTSIDE://:9092

参考链接:
https://juejin.cn/post/6893410969611927566
https://www.confluent.io/blog/kafka-listeners-explained/

http://www.yayakq.cn/news/392622/

相关文章:

  • 可以做兼职笔译的网站php学校网站模板
  • 网站html下载关于做公司网站
  • 用万网做网站试述网站建设的流程.
  • 网站建设应该考虑哪些方面鼎承世纪食品有限公司网页制作
  • 网站建设模块怎样划分网站开发的热门博客
  • 网站新闻标题字数站酷网海报素材图片
  • 奉贤做网站的网站维护企业
  • 网站开发毕设的需求分析南京中如建设公司
  • 网站静态页面访问很快php页面访问非常慢体检中心 网站建设方案
  • 乐清本地网站工程项目查询哪个网站
  • 网站改版被降权网站页面设计风格
  • 网站开发没有完成 需要赔偿吗为加强政协网站建设
  • 媒体网站开发网站建设基本功能
  • wordpress 获取父页面陕西网站建设优化建站
  • 作品集用什么网站做站群软件哪个好
  • 成功案例网站建设搜外友链平台
  • 微网站建设网络国内空间设计公司
  • 中国南昌企业网站制作所有域名后缀参考大全
  • 网站建设服务费属于哪个大类做网站的图片Pc端和手机端的区别
  • 网站排名监控工具企业网站能不能个人备案
  • 用asp做的几个大网站网站怎么快速做排名
  • 做设计最好的参考网站网站做整合页面
  • 最好的网站统计广州做一个营销网站多少钱
  • 上海协策网站制作php空间购买
  • 贵阳网站制作套餐wordpress导航大全
  • 做增员的保险网站app制作教程培训
  • 餐饮网站欣赏网站404页面优化
  • wordpress全站静态化专业重庆房产网站建设
  • 现货交易平台windows优化大师卸载
  • wordpress优化代码专业网站排名优化公司