Skip to content

如何执行全链路无编排高级蓝绿灰度发布

HaojunRen edited this page Oct 8, 2022 · 3 revisions

有少数公司希望蓝绿灰度发布尽量减少人工操作,降低运作成本,不愿意通过正规流程方式执行。在这里介绍一种固化式无编排高级蓝绿灰度发布

所谓固化式,即蓝绿灰度规则策略只配置一次后,永远不再变更

全链路无编排的流量染色

给服务实例分别打绿的版本标签,不需要通过时间戳方式或者数字递增方式

-Dmetadata.version=blue
-Dmetadata.version=green

技巧点之一

  • 本次发布执行时,旧服务版本标签为green,新服务版本标签为blue
  • 下次发布执行时,上次发布的新服务则变成旧服务(它的标记为blue),新上线的服务版本标签则为green
  • 以后每次发布执行时,greenblue的版本标签轮番交替使用,这次发布的新版本是blue,下次发布的新版本是green,再下次发布的新版本是blue...

全链路无编排的蓝绿灰度规则策略

蓝绿发布规则策略

当业务参数a等于1的时候,执行蓝路由;当业务参数a等于2的时候,执行绿路由

<?xml version="1.0" encoding="UTF-8"?>
<rule>    
    <strategy-release>
        <conditions type="blue-green">
            <condition id="condition-0" expression="#H['a'] == '1'" version-id="route-0"/>
            <condition id="condition-1" expression="#H['a'] == '2'" version-id="route-1"/>
        </conditions>

        <routes>
            <route id="route-0" type="version">blue</route>
            <route id="route-1" type="version">green</route>
        </routes>
    </strategy-release>
</rule>

灰度发布规则策略

当业务参数a等于3的时候,执行蓝路由占比90%,绿路由占比10%;当业务参数a等于4的时候,执行蓝路由占比70%,绿路由占比30%

<?xml version="1.0" encoding="UTF-8"?>
<rule>
    <strategy-release>
        <conditions type="gray">
            <condition id="condition-0" expression="#H['a'] == '3'" version-id="route-0=10;route-1=90"/>
            <condition id="condition-1" expression="#H['a'] == '4'" version-id="route-0=90;route-1=10"/>
        </conditions>

        <routes>
            <route id="route-0" type="version">blue</route>
            <route id="route-1" type="version">green</route>
        </routes>
    </strategy-release>
</rule>

技巧点之二

  • 蓝绿发布中a的值需要根据每次发布的而改变。这次发布a等于1执行的是新服务链路,下次发布a等于2执行的是新服务链路,再下次发布a等于1执行的是新服务链路...
  • 灰度发布中需要具备两条百分比相互颠倒的权重,例如,route-0=10;route-1=90和route-0=90;route-1=10。这次发布a等于3执行的是新服务链路10%权重,下次发布a等于4执行的是新服务链路10%权重,再发布a等于3执行的是新服务链路10%权重...
  • 每次发布通过a值交替改变锚定正确的链路路由

全链路无编排的故障转移

全链路网关和所有服务必须打开故障转移

# 启动和关闭版本故障转移。缺失则默认为false
spring.application.strategy.version.failover.enabled=true

技巧点之三

  • 不允许配置兜底路由。兜底路由一般是对旧版本而言,现有规则策略逻辑下,哪条链路是旧版本路由是不确定的,那么执行发布时候,业务参数不能缺失且必须命中,因为无兜底路由存在
  • 通过打开故障转移去兜底。假设,全链路为网关 -> 服务A -> 服务B -> 服务C,服务A和服务C要执行蓝绿灰度发布,服务B不需要。当整条链路切换到新版本路由时候,由于服务B不存在新版本,服务A调用服务B,服务A无法找到服务B的新版本,则故障转移到服务B的旧版本

全链路无编排蓝绿灰度发布的总结

优点

  • 不需要通过时间戳方式或者数字递增方式去打标签
  • 不需要每次发布都要去修改规则策略
  • 不需要指定具体要发布的服务列表

缺点

  • 要牢记每次发布中版本标签切换的情况,即greenblue分别代表是新版本路由还是旧版本路由
  • 要牢记业务参数在每次发布驱动链路的情况,即发布中,业务参数不能缺失且必须命中,发布后,业务参数必须缺失
  • 要牢记打开故障转移




2017-2050 ©Nepxion Studio Apache License

           

Total visits

讲义篇

集成篇

概念篇

实践篇

功能篇

配置篇

扩展篇

测试篇

升级篇

贡献篇

Clone this wiki locally