灰度发布(二)

继续上一篇的灰度发布,本文重点讲述kong网关是如何配置灰度发布规则的。
一、Kong网关在灰度发布中的重要作用
1、校验用户的htttp请求是否为灰度请求;
2、灰度规则的配置,允许多个规则的拼接;
3、需要为同一个service配置两个upstream,一个是正常的,另一个是灰度的。

二、主要流程


灰度发布(二)_第1张图片
主要操作流程.png

下面以用户服务为示例,演示在kong上面的操作。
1、新建UserService


灰度发布(二)_第2张图片
image.png

2、新建两个upstream


灰度发布(二)_第3张图片
image.png

3、新建route
灰度发布(二)_第4张图片
image.png

4、新建自定义的灰度插件
灰度发布(二)_第5张图片
image.png

灰度发布(二)_第6张图片
image.png

三、配置灰度规则


灰度发布(二)_第7张图片
灰度规则.png

支持多个规则,规则之间可以是“且”“或”的关系。
rules是一个数组结构:示例如下

[
  {
    "passway": "header",
    "paramName": "schoolId",
    "condition": "=",
    "paramValue":"2047"
  }
]

passway可以是header, parameter, cookie。
paramName就是我们说的Key值。

rule_type 是表示多个规则之间的逻辑关系。

至于判断是否匹配规则,是Lua的global.lua中的load()方法。

load("if " .. condition .. " then return true else return false end")

如果请求匹配上了灰度规则,下一步要做的就是设置对应的upstream了。
默认取的upstream是ngx.ctx.balancer_data.host,如果填写的不是它,则取UserServiceGray这个对应的upstream。

最后给请求打上灰度标签。

 ngx.req.set_header("gray", "true")

你可能感兴趣的:(灰度发布(二))