原文作者:Micheál Kingston - F5 Principal engineer
原文链接: Ingress NGINX 的替代方案:面向长期的开源 NGINX Ingress Controller
转载来源: NGINX 中文社区

 



Kubernetes 社区宣布 Ingress NGINX 将于 2026 年 3 月退役。此后,将不再有任何更新、bug修复或安全补丁发布。这个决定是在多年来该项目仅由 1-2 名开发者在夜间和周末维护之后做出的,再加上一些今年早些时候发生的严重安全问题(IngressNightmare CVE-2025-1974),这些情况清楚地表明该项目需要的资源远远超过了现有的支持。

就像您已经知道的那样,虽然您现有的部署将继续工作,但在没有安全更新的情况下运行是有风险的,且未来不会再有功能开发。当然,您已经了解这些情况。

您的选择(以及我们希望您考虑 NGINX OSS 的原因)

目前有多个优秀的 Ingress Controller 可供选择——如Traefik、HAProxy、Kong、基于 Envoy 的选项以及 Gateway API 的实现。Kubernetes 文档列出了其中许多项目,它们各有所长。

有些人可能知道,F5 维护着一个开源许可证的 NGINX Ingress Controller(有趣的是,它最初是 2016 年 NGINX, Inc. 的一个实习项目,在 F5 收购之前)。该项目是开源的,采用 Apache 2.0 许可证,并将一直保持这种状态。现在有一个专门的工程师团队正在开发它,并计划进行一系列升级。如果您已经熟悉 NGINX,并且只想要一个能顺利工作的解决方案,而不需要面对巨大的学习曲线,我们相信 F5 NGINX Ingress Controller for Kubernetes 是您最顺利的选择。

以下是我们认为您会喜欢它的原因:

  • 真正的开源:采用 Apache 2.0 许可证,拥有来自不同组织的 150 多名贡献者,而不仅仅是来自 F5。所有开发都在 GitHub 上公开进行,F5 承诺永将永远保持开源。此外,每两周会有社区电话会议
  • 最小的学习曲线:使用您已经熟悉的相同 NGINX engine。大多数 Ingress NGINX annotation 都有直接对应的功能,迁移指南为您的现有配置提供了清晰的映射
  • 可持续的维护:F5 的全职专属团队确保定期的安全更新、bug 修复和功能开发
  • 大规模生产验证:大约 40% 的 Kubernetes Ingress 部署由其提供支持,下载量超过 1000 万次,已在真实的生产环境中经过了实战检验
  • Kubernetes 原生设计:Custom Resource Definitions (CRDs)(如 VirtualServer, Policy, TransportServer)提供比 annotation overload 更整洁的配置,并内置校验以防止错误
  • 按需提供高级功能:支持金丝雀发布、A/B testing、流量切分、JWT 验证、限流、mTLS 等——这些都可以在开源版本中使用
  • 面向未来的架构:当您准备好转向 Gateway API 时,NGINX Gateway Fabric 的积极开发提供了清晰的迁移路径
  • 可选的商业支持:开源版本已经足够强大,但如果企业需要主动健康检查、动态重新配置、先进的会话持久化以及商业支持,可以选择 NGINX Plus 集成

迁移至 NGINX Ingress Controller

这是一个大致的迁移指南。您还可以查看我们文档网站上更详细的迁移指南。

第一阶段:盘点现状

  • 查看现有资源:记录您当前的 Ingress resource、annotation 和 ConfigMap
  • 检查 snippets:识别任何 nginx.ingress.kubernetes.io/configuration-snippet 注解
  • 确认正在使用:运行 kubectl get pods --all-namespaces --selector app.kubernetes.io/name=ingress-nginx
  • 并行设置:保持当前配置运行的同时,将 NGINX Ingress Controller 安装到一个单独的namespace

第二阶段:转换配置

  • 转换 annotation:您现有的大多数 annotation 在 NGINX Ingress Controller 中都有对应项——我们提供了全面的迁移指南来进行对照
  • 考虑使用 VirtualServer 资源:这些自定义资源比充满 annotation 的 Ingress 更简洁,并且提供更多控制,但这取决于您的选择
  • 或者继续使用 Ingress:如果您希望改动最小,它用标准的 Kubernetes Ingress 资源也是完全可行的
  • 处理边缘情况:对于任何无法直接映射的内容,您可以使用 snippet 或 Policy 资源

第三阶段:全面测试

  • 使用测试应用:创建一些指向 NGINX Ingress Controller 的测试 Ingress 规则
  • 并行运行:保持两个控制器同时运行,并通过新控制器路由测试流量
  • 验证功能:检查路由、SSL、限流、CORS、身份验证等您正在使用的功能
  • 检查性能:验证它是否按照您的需求处理流量

第四阶段:逐步切换

  • 从小处开始:首先迁移那些不太关键的应用
  • 缓慢切换流量:逐步更新 DNS 和路由
  • 密切监控:在切换过程中密切关注日志和指标
  • 保留应急通道:确保如果出现问题可以随时回滚

第五阶段:完成迁移

  • 完成迁移:迁移剩余的工作负载
  • 清理旧控制器:迁移完成后卸载社区版的 Ingress NGINX
  • 整理:删除不再需要的旧 ConfigMap 和资源

为什么选择 NGINX Ingress Controller(总结)

它是真正的开源

  • 完全开源,采用 Apache 2.0 协议,您不会被锁定在某个专有系统中
  • 来自多个组织的 150 多名贡献者(不仅限于 F5 员工)
  • 所有开发工作均在 GitHub 上公开进行
  • F5 承诺将始终保持开源,这是我们业务模式的核心
  • 拥有来自 F5 的可持续支持和投资

它是熟悉的领域

  • 使用您早已熟悉的相同 NGINX 引擎
  • 如果您一直在使用 Ingress NGINX,那么您已经掌握了 Ingress Controller 的大部分功能
  • 迁移文档展示了现有配置中大部分内容的直接映射关系
  • 您无需学习全新的东西

它在积极维护中

  • F5 NGINX 配备了专属的全职工程师
  • 提供定期的更新和安全补丁
  • 约 40% 的 Kubernetes 部署使用它,因此经过充分的测试
  • 如果您有需求,也可以获得商业支持(尽管开源版本已经非常稳定)

立足当下,通向未来

  • 我们准备了详尽的迁移指南,以确保您顺利过渡
  • 如果您需要迁移到商业版,我们可以协助将 annotation 和其他自定义配置迁移到 NGINX
  • NGINX 团队还提供了 Gateway API 实现方案——NGINX Gateway Fabric,当您准备迁移到 Gateway API 时可供使用

其他选项如何? Gateway API 是未来,但它仍在成熟发展过程中。Traefik、HAProxy、Kong 都是不错的选择,但如果您已经在使用 NGINX 并且想要最顺畅的迁移路径,我们相信 NGINX Ingress Controller 将是最佳选择。(当然,我们确实带有立场)

立即开始

准备好开始迁移了吗?您需要以下资源:

📚 阅读完整文档:https://docs.nginx.com/nginx-ingress-controller/

💻 克隆仓库:https://github.com/nginx/kubernetes-ingress

🐳 拉取镜像:https://hub.docker.com/r/nginx/nginx-ingress/

🔄 遵循迁移指南:https://docs.nginx.com/nginx-ingress-controller/install/migrate-ingress-nginx/

NGINX Ingress Controller 社区响应迅速且充满热情,您有足够的时间来规划这次迁移,但请不要等到 2026 年 3 月才动手。

Logo

AtomGit 是由开放原子开源基金会联合 CSDN 等生态伙伴共同推出的新一代开源与人工智能协作平台。平台坚持“开放、中立、公益”的理念,把代码托管、模型共享、数据集托管、智能体开发体验和算力服务整合在一起,为开发者提供从开发、训练到部署的一站式体验。

更多推荐