【JAVA】全链路灰度发布的实践分享

本文作者:曹磊,碧桂园服务技术经理,一个喜欢研究新技术方向的代码玩家

引言

在日常发布中,如何保证系统的高可用及稳定性,是我们始终以来的重要任务。我们深知一个可靠、高效的系统对用户体验和业务运行的关键性作用。

在软件发布与功能验证的环节,我们仍然会面临许许多多的挑战,全链路灰度发布方案专为微服务架构设计,旨在应对微服务架构下的灰度发布挑战。

前版本发布策略的现状及存在的问题

目前,大部分系统都是应用了基于k8s容器的滚动发布方案,或者在滚动发布的逻辑上,实现了优雅停机的逻辑。

1.1 现状

  • 优雅停服1个节点,保留其他节点依然提供生产服务
  • 通过日志,观察一段时间,看新的节点是否运行正常。如果不正常,就回滚版本
  • 如果运行正常,继续1、2的步骤,一直到所有节点部署完成
  • 测试人员上生产做基本验证

1.2 存在问题

  • 不能有效的控制灰度流量,导致测试人员要全部节点部署完,才可以做生产验证
  • 目前的滚动发布逻辑,无法做到增量更新,一旦新版本出了问题,肯定会影响到生产的运行
  • 难以实现全天候平滑稳定的发版
  • 如果版本发布涉及不同服务之间的依赖关系,或者前后端都需要调整,当前策略无法一步到位满足全链路灰度测试场景

业界常用的软件发布策略对比

3 什么是灰度发布?为什么需要采用灰度发布?

3.1 什么是灰度发布?

灰度发布,简单来说就是先小范围进行版本发布,充分验证功能符合预期后,再逐步扩大发布范围。如果出现负面反馈或功能异常时,则需要停止放量,回滚到原先的稳定版本。

从技术上来说,灰度发布是一种流量控制方案,对服务的请求流量按用户或者其它特性打标签,保证特定标签的流量只经过特定标签的服务路径

3.2 为什么采用灰度发布?

1、降低发布风险

在新版本发布之前,通过灰度发布把新版本先部署到一小部分用户,以便能更快地发现并解决潜在的问题。

2、提高发布质量

因为在灰度发布期间可以及时发现和解决问题,所以能够在全量发布之前不断完善代码质量,提高系统稳定性和可靠性。

3、优化用户体验

在灰度发布期间,我们可以根据用户反馈来针对性地优化产品功能和界面,确保用户使用的体验最佳。

4、降低对系统性能的影响

由于灰度发布只向部分用户发布新版本,所以能够限制新版本对整个系统的影响。

全链路灰度发布的实现思路

全链路流量路由目前有两种主流实现:

1、基于 Istio

采用 Istio 这个开源 Service Mesh 组件,通过在每个服务的容器中部署 Envoy 透明代理,拦截服务之间的网络通信并按指定规则转发,从而实现了全链路流量路由,无需对现有代码进行修改。

2、基于服务发现组件

通过支持为服务设置元数据的服务注册中心,如 Nacos,可以标记服务实例的特征,例如灰度版本。每个服务可以通过注册中心获取其他服务实例的版本信息,并通过修改代码逻辑或 Java Agent 实现流量路由

接下来,我们详细来讲基于服务发现组件来实现灰度发布逻辑的方案。

灰度发布逻辑工程实践

5.1 灰度链路流程图

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值