其他分享
首页 > 其他分享> > K8S基于Rancher的灰度发布

K8S基于Rancher的灰度发布

作者:互联网

简介

Nginx-ingress 是一个以 Nginx 为核心组件的 K8S 负载均衡工具,支持通过配置 Ingress 规则的 Annotations 来实现不同场景下的灰度发布和测试。

Ingress Annotations 支持以下 4 种 Canary 规则:

注意:金丝雀规则按优先顺序进行如下排序: canary-by-header - > canary-by-cookie - > canary-weight

我们可以把以上的四个 Annotation 规则可以总体划分为以下两类:

注意: Nginx-ingress 在 0.21.0 版本中引入的 Canary 功能,因此要确保 ingress 版本大于等于 0.21.0。

测试准备

测试步骤

测试场景 1:基于 header 实现蓝绿或者 A/B test

  1. 我们基于 V2 进行 ingress 的配置,添加 ingress 的 annotation:

  2. 我们在客户端执行命令(带 Rancher:Best 的请求头):

     
    curl -H "Rancher: Best" http://es01.zyl.com

    可以看到当我们带请求头去访问 es01.zyl.com 这个页面时,流量会被自动转发到 V2 的页面里,当我们不带请求头直接访问就会是 V1 版本的页面

     
    curl  http://es01.zyl.com

测试场景 2:基于流量实现灰度或者蓝绿

  1. v2 版本 ingress annotation 配置如下:

    此例中我配置的权重是 50%流量会进入 V2 版本,因此我们在浏览器里不断刷新访问后会发现 V1 和 V2 两个页面,总体概率是 50%到 V2,50%到 V1,可以直接调整权重的值实现灰度发布。

两种场景的 yaml 文件截图

 

标签:ingress,请求,nginx,Canary,Header,灰度,canary,Rancher,K8S
来源: https://www.cnblogs.com/minimeta/p/16367909.html