蓝绿部署、滚动部署、金丝雀(Canary)发布、灰度发布、A/B测试

最近看到Canary发布,一时没有反应过来是什么,一查才发现就是鼎鼎有名的金丝雀发布,发现经常一起出现的还有灰度发布、蓝绿部署、滚动部署、A/B测试,故一起学习一下这几个概念。

1. 蓝绿部署

  • 目的:减少发布时的中断时间、能够快速撤回发布
  • 蓝绿部署中,一共有两套系统:一套正在提供服务的系统,标记为“绿色”;另一套是准备发布的系统,标记为“蓝色”。两套系统都是功能完善的,并且正在运行的系统,只是系统版本和对外服务情况不同。
    • 蓝色系统作用:用来做发布前测试,测试过程中发现任何问题,可以直接在蓝色系统上修改,不干扰用户正在使用的系统。
    • 蓝色系统经过反复的测试、修改、验证,确定达到上限标准后,直接将用户切换到蓝色系统。
    • 切换后的一段时间,依旧是蓝绿两套系统并行,但是用户访问的已经是蓝色系统。这段时间内观察蓝色系统(新系统)工作状态,如果出现问题,直接切回绿色系统。
    • 当确信对外提供服务的蓝色系统工作正常,不对外提供服务的绿色系统已经不再需要的时候,蓝色系统正式成为对外提供服务系统,成为新的绿色系统。原先的绿色系统可以销毁,将资源释放出来,用于部署下一个蓝色系统。
  • 蓝绿部署只是上线策略中的一种。
  • 蓝绿部署能够简单快捷实施的前提是目标系统是非常内聚的,如果目标系统相当复杂,那么如何切换、两套系统的数据是否需要以及如何同步等,都需要仔细考虑。

2. 滚动部署

  • 滚动部署:就是在发布过程并不一下子启动所有新版本,而是先启动一台新版本,再停止一台老版本,然后再启动一台新版本,再停止一台老版本,直到全部发布完成。
  • 滚动部署能够解决蓝绿部署对硬件要求增倍的问题。

3. 金丝雀(Canary)发布

金丝雀发布名称来源:

17世纪,英国矿井工人发现,金丝雀对瓦斯这种气体十分敏感。空气中哪怕有极其微量的瓦斯,金丝雀也会停止歌唱;而当瓦斯含量超过一定限度时,虽然人类毫无察觉,金丝雀却早已毒发身亡。当时在采矿设备相对简陋的条件下,工人们每次下井都会带上一只金丝雀作为“瓦斯检测指标”,以便在危险状况下紧急撤离。

  • 金丝雀(Canary)发布也是一种发布策略,即灰度发布。
  • 金丝雀发布指的是在生产环境中分阶段逐步更新后端应用的版本(需要具备流量控制能力),在小范围验证符合预期之后,再推广至整个生产环境。
  • 金丝雀发布的好处:可以用真实环境测试新版本,当新版本存在问题时最多只影响部分用户,且支持安全快速的回滚策略(将路由到新版本上的流量切换到其他老版本机器上即可)。
  • 蓝绿部署是准备两套系统,在两套系统之间进行切换;金丝雀策略是只有一套系统,逐渐替换这套系统。

4. A/B测试

  • A/B测试和蓝绿部署、金丝雀完全是两回事。
    • 蓝绿部署和金丝雀是发布策略,目标是确保新上线的系统稳定,关注的是新系统的BUG、隐患。
    • A/B测试是效果测试,同一时间有多个版本的服务对外服务,这是服务都是经过足够的测试,达到了上线标准的服务,有差异但是没有新旧之分。(它们上线的时候可能采用了蓝绿部署的方式)
  • A/B测试关注的是不同版本的服务的实际效果,譬如说转化率、订单情况等。
  • A/B测试时,线上同时运行多个版本的服务,这些服务通常会有一些体验上的差异,例如页面样式、颜色、操作流程不同。相关人员通过分析各个版本服务的实际效果,选出效果最好的版本。

参考:https://ixyzero.com/blog/archives/4722.html

posted @ 2021-04-29 20:48  AmyZYX  阅读(1747)  评论(0编辑  收藏  举报