
本文介绍通过 Jenkins 构建流水线的方式实现全链路灰度功能。
在发布过程中,为了整体稳定性,我们总是希望能够用小部分特定流量来验证下新发布应用是否正常。
即使新版本有问题,也能及时发现,控制影响面,保障了整体的稳定性。
01
整体架构
Aliware
我们以如下 Demo 为例:

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

其中,在灰度验证中,有几种不同的策略:
直接使用线上小部分流量来测试(按照百分比放量)
从线上按照特定规则选择流量(比如特定的 header、特定的 cookie 等)
在客户端或浏览器上标识出流量是否灰度(比如通过 header 传递)
02
部署应用&创建泳道
Aliware
按照参考文档部署应用后,我们首先要区分线上流量和灰度流量。
创建泳道组,将整个链路涉及到的应用全选:

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

注:没有匹配的流量,会走到基线环境,也就是没有打标的应用节点上。
配置完成后,访问网关,如果不符合灰度规则,走基线环境:

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

03
配置 Jenkins 流水线
Aliware
本文实践需要将源码打包后执行镜像推送,请确保 Jenkins 有权限推送到镜像仓库中。具体操作,请参见使用 kaniko 构建和推送容器镜像。
在 Jenkins 命名空间下使用生成的 config.json 文件创建名为 jenkins-docker-cfg 的 Secret。
kubectl create secret generic jenkins-docker-cfg -n jenkins --from-f

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

被折叠的 条评论
为什么被折叠?



