讨论:无法访问不同网段的Kafka问题

问题

X同学:A网段的机器,访问B网段部署的Kafka集群,中间做了网络映射,映射成A网段可以访问的IP地址,A网段程序里配置bootstrap.servers就是这些可以访问的地址。但是最后发现还是无法访问,并且日志里看到了B网段的IP地址。请问怎么处理。

解决办法

kafka可以配置成注册的IP是公网IP:

listeners=INSIDE://<内网IP>:9092,OUTSIDE://<公网IP>:端口 advertised.listeners=INSIDE://内网IP:9092,OUTSIDE://<公网IP>:端口 listener.security.protocol.map=INSIDE:SASL_PLAINTEXT,OUTSIDE:SASL_PLAINTEXT inter.broker.listener.name=INSIDE

试试这个方案,行的话,就不用多做一层映射了。

进一步深入讨论此类问题

如果你们的网络映射配置的没错,那么感觉是跟redis cluster一样的问题。kafka集群的节点之间是使用的内网段地址进行交互,他们压根儿不知道有映射的这个外网地址。

解决问题的办法有几种,简单点的是:让client端的网络上再加一层转换,可以把kafka的内网IP解析成作了映射的外网IP。

更一般化的来看:两个机器A和B在不通的两个网段,IP分别为:10.1.1.101和10.1.2.102。现在想让A能访问B的端口9092。

为了实现这个目标我们已经实现了A和B同时都能访问P(IP 10.1.0.202),那么我们设置对于10.1.0.202:9092的映射转到B,即可实现A通过配置访问P来间接访问到B。

然后我们发现B在一个集群里,还有一个节点C IP为10.1.2.103,A请求B后,会拿到这个C的信息,也就是10.1.2.103,然后发起访问。这时候我们会发现A是无法访问C的,而且上面的办法也不能对C来使用,因为C的IP地址是B给的。

我们新增一个映射到C的IP 10.1.0.203,没地方修改成一个新的映射地址。此时,可以通过修改iptables规则,让A对于10.1.2.103的访问自动转到10.1.0.203。

iptables -t nat -A POSTROUTING -p tcp --dport 9092 -d 10.1.0.203 -j SNAT --to-source 10.1.2.103

类似这种,但是这个办法的一个不足之处是,所有访问的机器都要加这个路由条件。

这个问题的本质是,redis/kafka 集群不是被设计成跨不同的网络访问区来使用的。

相关推荐
itmrl13 小时前
Redis高可用方案之哨兵模式搭建
redis
懂得节能嘛.15 小时前
【Java动态线程池】Redis监控+动态调参
java·开发语言·redis
每天进步一点_JL15 小时前
事务与消息中间件:分布式系统中的可见性边界问题
分布式·后端
凌寒1116 小时前
Linux(Debain)安装Redis、数据迁移
linux·运维·服务器·redis
⑩-17 小时前
基于Redis Lua脚本的秒杀系统
java·redis
静若繁花_jingjing18 小时前
ZooKeeper & Nacos
分布式·zookeeper·云原生
wanhengidc18 小时前
云手机中分布式存储的功能
运维·服务器·分布式·游戏·智能手机·云计算
三翼鸟数字化技术团队18 小时前
基于redis的多资源分布式公平锁的设计与实践
redis·后端
u***j32418 小时前
HarmonyOS分布式能力核心技术深度解析
分布式·华为·harmonyos
h***346318 小时前
Redis安装教程(Windows版本)
数据库·windows·redis