Gloo项目v1.18.15版本发布:解决网关路由委托内存泄漏问题

Gloo项目v1.18.15版本发布:解决网关路由委托内存泄漏问题

gloo The Feature-rich, Kubernetes-native, Next-Generation API Gateway Built on Envoy gloo 项目地址: https://gitcode.com/gh_mirrors/glo/gloo

Gloo是一个基于Envoy构建的云原生API网关,它提供了丰富的流量管理功能,包括负载均衡、路由、安全策略等。作为Kubernetes原生网关解决方案,Gloo能够简化微服务架构中的API管理,支持多种协议和函数即服务(FaaS)平台。

在最新发布的v1.18.15版本中,Gloo团队重点修复了一个可能导致内存泄漏的关键问题,该问题与网关路由委托功能相关。路由委托是Gloo的一项重要特性,允许管理员将路由规则的管理权下放给不同的团队或命名空间,实现更灵活的权限分配和路由管理。

本次修复的核心问题是:当存在循环引用命名空间的路由委托配置时,系统会消耗大量内存。具体来说,当一个父路由委托给其自身命名空间中的通配符路由时,由于路由链构建过程中缺少必要的检查,系统会不必要地保留大量路由信息,即使这些子路由实际上并不会附加到父路由上。

问题的根源在于最近的一次重构中,为了支持KRT集成,将路由查询与路由翻译解耦时,对子路由的解析变得过于宽松。在重构前,系统会早期忽略那些与父引用不匹配的子路由,而重构后这一检查被遗漏,导致在评估委托链时递归调用消耗过多内存。

修复方案采用了早期修剪路由链的方法,即在初始路由链构建阶段就忽略那些与父引用不匹配的子路由。这种方案虽然可能不是最优解(因为理论上可以进一步修剪子路由列表),但它有效地解决了内存泄漏问题,同时避免了引入更复杂的O(N^2)计算逻辑可能带来的性能下降和新bug风险。

从技术实现角度看,这一修复体现了Gloo团队对系统稳定性的重视。他们选择了风险较低的解决方案,将更深入的优化留待未来版本。这种权衡在软件工程中很常见——在解决紧急问题的同时,避免引入可能导致更大范围不稳定的变更。

对于使用Gloo网关路由委托功能的用户来说,升级到v1.18.15版本将显著改善系统在复杂路由委托场景下的内存使用效率,特别是在存在循环命名空间引用的配置中。这一修复也提醒我们,在实现递归逻辑时,必须特别注意边界条件和早期修剪,以防止资源耗尽问题。

Gloo作为云原生API网关的持续演进,展现了开源项目对用户反馈的快速响应能力。通过不断优化核心功能,Gloo正成为企业级微服务架构中不可或缺的基础设施组件。

gloo The Feature-rich, Kubernetes-native, Next-Generation API Gateway Built on Envoy gloo 项目地址: https://gitcode.com/gh_mirrors/glo/gloo

创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

费跃鹏Half-Dane

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值