Kube-OVN Underlay + MetalLB 负载均衡器 Service 配置
目录
概述前提条件环境要求流量路径配置步骤1. 使用 VLAN 子接口配置 ProviderNetwork2. 配置 Kube-OVN Controller 参数3. 配置 Underlay 子网外部地址功能4. 创建 MetalLB 外部地址池5. 创建示例应用和负载均衡器 Service6. 验证配置7. 迁移现有 Service概述
此方案用于将 MetalLB L2 模式与 Kube-OVN Underlay 网络集成。它允许用户使用 Underlay 子网 IP 作为 MetalLB 负载均衡器 Service VIP,并将流量直接转发到后端业务 Pods。
⚠️ 关键:负载均衡器 VIP 与后端 Pod IP 必须位于同一 Underlay 子网中。
⚠️ 关键:禁止内部 Pod 访问负载均衡器 Service IP。该 IP 仅供外部客户端访问。
前提条件
环境要求
- ACP 版本:>= 4.2.2
- IP 支持:仅支持 IPv4(当前不支持 IPv6)
流量路径
流量图:
配置步骤
1. 使用 VLAN 子接口配置 ProviderNetwork
重要:必须使用 VLAN 子接口。
配置 Kube-OVN Underlay 网络以自动创建 VLAN 子接口:
⚠️ 警告:单独修改
ProviderNetwork或Vlan资源时,Underlay 网络连通性将会中断。只有在这两个资源都完成配置并保持同步后,网络连通性才会恢复。请在维护窗口期间安排配置变更,以尽量减少服务中断。
2. 配置 Kube-OVN Controller 参数
为 LoadBalancer 功能配置所需的 Kube-OVN controller 参数:
使用 Web 控制台:
- 导航至 管理员 > Marketplace > Cluster Plugins,然后搜索
ovn,找到 Alauda Container Platform Networking for Kube-OVN - 在插件行中,点击操作菜单(竖向 ⋮),然后选择 Update 打开配置对话框
- 配置以下设置:
- Skip CT for Dst LPort IPs:No
- Enable OVN LB Local:Yes
3. 配置 Underlay 子网外部地址功能
编辑 Underlay 子网,为 LoadBalancer 使用保留一个 IP 范围:
重要:外部地址池 IP 必须位于 Underlay 子网内。
修改 Underlay 子网参数 spec.enableExternalLBAddress: true:
4. 创建 MetalLB 外部地址池
部署地址池:
5. 创建示例应用和负载均衡器 Service
部署应用:
6. 验证配置
7. 迁移现有 Service
对于使用旧地址池(仅节点子网)的现有 Service,您可以将其迁移到新的 Underlay 地址池:
对于新 Service,直接添加注解: