Linux bridge使用dummy接口调用IPVS的问题
Linux bridge使用dummy接口调用IPVS的问题
在IPVS: How Kubernetes Services Direct Traffic to Pods一文中,作者给出了一个简单的组网(如下)来模拟kubernetes是如何使用IPVS进行通信的。

问题描述
当在netns_leah
命名空间中测试通过VIP访问netns_dustin
中的服务时,发现如果不创建一个类型为dummy
,且IP为VIP(10.100.100.100)的接口时,访问是不通的。作者怀疑bridge_home
接口并没有调用IPVS规则。
如下图,IPVS规则实际是iptables处理路径上挂载的钩子。

问题分析
按照原文的步骤,创建dummy接口之后就可以成功执行如下命令,从netns_dustin
命名空间通过VIP访问netns_dustin
中的服务:
sudo ip netns exec netns_dustin curl 10.100.100.100:8080
抓包发现执行逻辑如下:


如果不配置dummy接口,将不会执行上述第四步,即bridge_home
不会发起到netns_dustin
的ARP广播请求,由此可以怀疑,从netns_leah
到bridge_home
的SYNC报文并没有经过IPVS规则,由于无法解析VIP,bridge_home
将根据默认路由转发目的地为VIP的报文。
本机的IP地址(192.168.118.148
)和默认路由如下:

删除dummy接口,并在出接口ens33
上抓包,发现bridge_home
果然按照默认路由转发了报文。

总结
dummy接口相当于提供了一个让bridge_home
进入iptables的机会,这样就可以使用IPVS规则处理报文。
本文来自博客园,作者:charlieroro,转载请注明原文链接:https://www.cnblogs.com/charlieroro/p/14653735.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!