通过Jenkins构建CI/CD实现全链路灰度

本文介绍了通过Jenkins构建流水线以实现全链路灰度功能,包括整体架构、部署应用、创建泳道、配置Jenkins流水线,以及结果验证、全量发布和回滚应用的详细步骤。通过灰度部署,可以有效验证新版本的稳定性并控制影响范围。

c78610f46330498e1f7085b28ff44196.gif

本文介绍通过 Jenkins 构建流水线的方式实现全链路灰度功能。

在发布过程中,为了整体稳定性,我们总是希望能够用小部分特定流量来验证下新发布应用是否正常。

即使新版本有问题,也能及时发现,控制影响面,保障了整体的稳定性。

01

整体架构

Aliware

我们以如下 Demo 为例:

5d9c13ff78dcfed5331da32f5f0ebb5b.png

为了保证稳定,我们约定如下上线流程:

d31be616a94ef95a346926aa969a6ea0.png

其中,在灰度验证中,有几种不同的策略:

  • 直接使用线上小部分流量来测试(按照百分比放量)

  • 从线上按照特定规则选择流量(比如特定的 header、特定的 cookie 等)

  • 在客户端或浏览器上标识出流量是否灰度(比如通过 header 传递)

02

部署应用&创建泳道

Aliware

按照参考文档部署应用后,我们首先要区分线上流量和灰度流量。

创建泳道组,将整个链路涉及到的应用全选:

5ef858e320224a9051e42eeee1d90826.png

然后创建泳道组,将符合规则的应用划入 gray 泳道:

ab0460bb3136309a9cc5afeabf3eba03.png

注:没有匹配的流量,会走到基线环境,也就是没有打标的应用节点上。

配置完成后,访问网关,如果不符合灰度规则,走基线环境:

5b387f834ded4f360efc460d13c12aae.png

如何符合灰度规则,走灰度环境:

ba9c76fb5f99e8d5344730723cf787e3.png

03

配置 Jenkins 流水线

Aliware

本文实践需要将源码打包后执行镜像推送,请确保 Jenkins 有权限推送到镜像仓库中。具体操作,请参见使用 kaniko 构建和推送容器镜像。

在 Jenkins 命名空间下使用生成的 config.json 文件创建名为 jenkins-docker-cfg 的 Secret。

kubectl create secret generic jenkins-docker-cfg -n jenkins --from-f
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值