首页 > 其他分享 >蓝绿发布,红黑发布和灰度发布的优缺点。

蓝绿发布,红黑发布和灰度发布的优缺点。

时间:2022-12-08 16:39:16浏览次数:35  
标签:部署 蓝绿 发布 集群 红黑 版本 灰度


科学部署的意义:

尽可能减少服务停机时间,控制新版本带来的质量风险。

各种部署方式的定义

蓝绿发布,红黑发布和灰度发布的优缺点。_灰度

蓝绿部署

蓝绿部署,是采用两个分开的集群对软件版本进行升级的一种方式。它的部署模型中包括一个蓝色集群 A 和一个绿色集群 B,在没有新版本上线的情况下,两个集群上运行的版本是一致的,同时对外提供服务。

系统升级时,蓝绿部署的流程是:

蓝绿发布,红黑发布和灰度发布的优缺点。_新版本_02

首先,从负载均衡器列表中删除集群 A,让集群 B 单独提供服务。然后,在集群 A 上部署新版本。

蓝绿发布,红黑发布和灰度发布的优缺点。_运维开发_03

接下来,集群 A 升级完毕后,把负载均衡列表全部指向 A,并删除集群 B,由 A 单独提供服务。

蓝绿发布,红黑发布和灰度发布的优缺点。_运维开发_04

在集群 B 上部署完新版本后,再把它添加回负载均衡列表中。

蓝绿发布,红黑发布和灰度发布的优缺点。_运维开发_05

这样,我们就完成了两个集群上所有机器的版本升级。

蓝绿发布,红黑发布和灰度发布的优缺点。_新版本_06

红黑部署

与蓝绿部署类似,红黑部署也是通过两个集群完成软件版本的升级。

蓝绿发布,红黑发布和灰度发布的优缺点。_新版本_07

当前提供服务的所有机器都运行在红色集群 A 中,当需要发布新版本的时候,具体流程是这样的:

蓝绿发布,红黑发布和灰度发布的优缺点。_负载均衡_08

先在云上申请一个黑色集群 B,在 B 上部署新版本的服务; 等到 B 升级完成后,我们一次性地把负载均衡全部指向 B;

蓝绿发布,红黑发布和灰度发布的优缺点。_新版本_09

把 A 集群从负载均衡列表中删除,并释放集群 A 中所有机器。

蓝绿发布,红黑发布和灰度发布的优缺点。_运维开发_10

这样就完成了一个版本的升级。

可以看到,与蓝绿部署相比,红黑部署只不过是充分利用了云计算的弹性伸缩优势,从而获得了两个收益:一是,简化了流程;二是,避免了在升级的过程中,由于只有一半的服务器提供服务,而可能导致的系统过载问题。

至于这两种部署方式名字中的“蓝绿”“红黑”,只是为了方便讨论,给不同的集群取的名字而已,通过不同颜色表明它们会在系统升级时运行不同的版本。

蓝绿发布,红黑发布和灰度发布的优缺点。_新版本_11

灰度部署

灰度发布,也被叫作金丝雀发布。与蓝绿部署、红黑部署不同的是,灰度发布属于增量发布方法。也就是说,服务升级的过程中,新旧版本会同时为用户提供服务。

灰度发布的具体流程是这样的:在集群的一小部分机器上部署新版本,给一部分用户使用, 以测试新版本的功能和性能;确认没有问题之后,再对整个集群进行升级。简单地说,灰度发布就是把部署好的服务分批次、逐步暴露给越来越多的用户,直到最终完全上线。

蓝绿发布,红黑发布和灰度发布的优缺点。_运维开发_12


蓝绿发布,红黑发布和灰度发布的优缺点。_新版本_13


蓝绿发布,红黑发布和灰度发布的优缺点。_灰度_14

之所以叫作灰度发布,是因为它介于黑与白之间,并不是版本之间的直接切换,而是一个平滑过渡的过程。

蓝绿发布,红黑发布和灰度发布的优缺点。_运维开发_15


蓝绿发布,红黑发布和灰度发布的优缺点。_灰度_16


蓝绿发布,红黑发布和灰度发布的优缺点。_灰度_17


标签:部署,蓝绿,发布,集群,红黑,版本,灰度
From: https://blog.51cto.com/u_15906694/5922705

相关文章