Kube-OVN 中大规模子网策略路由添加性能问题分析
在 Kube-OVN 网络插件中,当集群规模较大时,添加策略路由的操作可能会遇到严重的性能问题。本文将深入分析这一问题的根源,并探讨可能的优化方向。
问题现象
在包含 10 个节点、260 个子网和约 5000 个端口的 Kube-OVN 集群中,用户观察到以下现象:
- 控制器重启后,"add policy route"操作执行极其缓慢,每条策略路由添加耗时 1-3 秒
- 工作队列深度下降缓慢,处理 100 个子网需要约 27 分钟
- 存在大量重复的策略路由添加操作
- 在添加策略路由和重置 ACL 之间存在约 10 秒的延迟
根本原因分析
策略路由检查机制
Kube-OVN 在添加每条策略路由前,都需要执行 listLogicalRouterPoliciesByFilter 操作来检查该路由是否已存在。在 v1.12.28 版本中,这一操作平均耗时约 600ms。
对于包含 10 个节点和 260 个子网的集群,理论上需要执行 260×10=2600 次策略路由添加操作。每次操作都需要检查所有现有策略路由,导致总检查次数达到 260×260×10=676,000 次,这是性能瓶颈的主要原因。
ACL 处理延迟
在子网创建过程中,ResetLogicalSwitchAclSuccess 事件与 ValidateLogicalSwitchSuccess 之间存在约 10 秒的延迟。这表明 ACL 处理可能也存在类似的性能问题,特别是在集群配置了大量安全组(约 300 个)的情况下。
缓存失效问题
虽然 Kube-OVN 使用了 whereCache 机制来缓存策略路由查询结果,但每次添加新策略路由都会使缓存失效,导致后续查询需要重新获取完整路由列表。
优化方案
策略路由查询优化
在较新版本(如 v1.14.0)中,通过优化 listLogicalRouterPoliciesByFilter 的实现,将查询时间从 600ms 降低到约 10ms。用户可以通过 cherry-pick 相关提交(如 a6f13a6 和 b76c044)到旧版本中获得这一改进。
批量处理机制
当前实现是逐个添加策略路由,可以考虑改为批量处理模式:
- 预先收集所有需要添加的策略路由
- 一次性查询现有路由状态
- 批量添加缺失的路由
ACL 处理优化
对于 ACL 处理延迟问题,可以考虑:
- 并行处理不同子网的 ACL
- 优化 ACL 查询机制,减少全量查询
- 实现增量更新机制,避免每次重置所有 ACL
总结
Kube-OVN 在大规模集群中的策略路由添加性能问题主要源于重复的全量查询操作。通过优化查询实现、引入批量处理机制和改进缓存策略,可以显著提升性能。对于生产环境中的大规模集群,建议升级到包含这些优化的新版本,或手动应用相关补丁。
未来,Kube-OVN 可以考虑实现更智能的路由管理机制,如基于事件触发的增量更新、更细粒度的缓存策略等,以进一步提升大规模集群下的网络配置性能。
kernelopenEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。C0123
let_datasetLET数据集 基于全尺寸人形机器人 Kuavo 4 Pro 采集,涵盖多场景、多类型操作的真实世界多任务数据。面向机器人操作、移动与交互任务,支持真实环境下的可扩展机器人学习00
mindquantumMindQuantum is a general software library supporting the development of applications for quantum computation.Python059
PaddleOCR-VLPaddleOCR-VL 是一款顶尖且资源高效的文档解析专用模型。其核心组件为 PaddleOCR-VL-0.9B,这是一款精简却功能强大的视觉语言模型(VLM)。该模型融合了 NaViT 风格的动态分辨率视觉编码器与 ERNIE-4.5-0.3B 语言模型,可实现精准的元素识别。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00