各种部署方式的定义

我们先来看看蓝绿部署(Blue-green Deployment)、红黑部署(Red-black Deployment)和灰度发布(Gray Release ,或 Dark Launch)的定义和流程吧。

蓝绿部署

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

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

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

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

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

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

红黑部署

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

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

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

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

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

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

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

灰度发布

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

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

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

之所以又被叫作金丝雀发布,是因为金丝雀对瓦斯极其敏感,17  世纪时英国矿井工人会携带金丝雀下井,以便及时发现危险。这就与灰色发布过程中,先发布给一部分用户来测试相似,因而得名。

好了,以上就是几种有颜色的部署发布方式了。如果你还有哪些地方理解得不够透彻,可以去网络上搜索相关文章,或者直接给我留言吧。接下来,我将继续按照黄金圈法则,来帮助你深入了解这些部署、发布方式的 Why、How 和 What。

蓝绿、红黑部署和灰度发布的 Why

究其根本,这些部署、发布方法,是为了解决频繁发布的生产模式带来的两个问题:

减少发布过程中新旧服务切换造成的服务停止时间。蓝绿部署和红黑部署都能实现无宕机时间部署(0 downtime deployment)。

控制新版本发布因为质量问题带来的风险。灰度发布就是一个例子。

蓝绿红黑灰度发布的 How

实现这两个目标的基本原则,是把服务上线过程拆分为部署、发布和发布后 3 个阶段,并

充分利用这 3 个阶段的特点来提高服务上线的效率、质量和安全性。

这 3 个阶段的详细定义和特点分别是:

部署(deploy),指的是我们把一个代码包拷贝到服务器上运行,但并不把它暴露给用  户,也就是并不给用户提供服务。这个阶段比较耗时,但因为还没有面向用户,所以风险很小。

发布(release),是把部署好的服务暴露给用户的过程,也就是开始真正上线服务用户  了。这个过程可以通过负载均衡的切换很快实现,但风险很大,一旦出现问题损失就会比较大。

发布后(post-release),指的是服务完全上线以后的阶段。因为产品已经完全上线,我们的主要工作不再是预防,而是变成了监控和降低损失。

以红黑部署为例,从开始在新生成的集群 B 上部署新的版本,到线上的流量通过负载均衡指向 B 之前,是处于部署阶段;而负载均衡从 A 指向 B 的过程,就是发布阶段;等到负载均衡完全指向 B 之后,就进入了发布后阶段。

部署、发布、上线这几个名词,其实区分不太明显,我们平时在讨论服务部署上线时,也经常会混用。在这里,我之所以要和你明确区分这几个阶段,是因为我们可以针对每个阶段的特点来实现两个目标:

提高上线产品的效率,也就是减少发布过程中新旧服务切换造成的服务停止时间。提高上线产品的安全性,也就是控制新版本引入的质量问题。

蓝绿、红黑部署和灰度发布 What

关于提高上线产品的效率,实践主要有两个:一是利用负载均衡切换线上流量,二是使用功能开关切换线上流量。这两种方法都比较简单。

而提高上线产品的安全性,相对来说就比较复杂了,但又很重要。因为在敏捷、持续交付等开发模式愈发流行的今天,产品的研发节奏越来越快,我们必须在上线过程中,在生产环境上进行更多的测试,以保证产品质量。

蓝绿发布,红黑发布和灰度发布是什么相关推荐

  1. 14.每日一读-到底什么是蓝绿、红黑、灰度发布

    1.科学部署的意义 尽可能减少服务停机时间 控制新版本带来的质量风险 2.全量发布与增量发布 3.蓝绿发布 1.我有两个应用集群,应用集群A与应用集群B,这两个集群的版本都是v1.0,现在使用蓝绿部署 ...

  2. 蓝绿部署、AB测试、灰度发布、⾦丝雀发布、滚 动发布的概念与区别

    ⼀.蓝绿部署(Blue/Green Deployment) 过去的 10 年⾥,很多公司都在使⽤蓝绿部署(发布)来实现热部署,这种部署⽅式具有安全.可靠的特点.蓝绿部署虽然算不上" Sliv ...

  3. 微服务部署:蓝绿部署、滚动部署、灰度发布等部署方案对比与总结

    在项目迭代的过程中,不可避免需要"上线".上线对应着部署,或者重新部署:部署对应着修改:修改则意味着风险. 目前有很多用于部署的技术,有的简单,有的复杂:有的得停机,有的不需要停机 ...

  4. 微服务部署:蓝绿部署、滚动部署、灰度发布、金丝雀发布

    在项目迭代的过程中,不可避免需要"上线".上线对应着部署,或者重新部署:部署对应着修改:修改则意味着风险. 目前有很多用于部署的技术,有的简单,有的复杂:有的得停机,有的不需要停机 ...

  5. 微服务部署:蓝绿部署、滚动部署、灰度发布

    在项目迭代的过程中,不可避免需要"上线".上线对应着部署,或者重新部署:部署对应着修改:修改则意味着风险. 目前有很多用于部署的技术,有的简单,有的复杂:有的得停机,有的不需要停机 ...

  6. 蓝绿部署、滚动部署、灰度发布、金丝雀发布-概念介绍---应用部署001

    在项目迭代的过程中,不可避免需要"上线".上线对应着部署,或者重新部署:部署对应着修改:修改则意味着风险. 目前有很多用于部署的技术,有的简单,有的复杂:有的得停机,有的不需要停机 ...

  7. 蓝绿部署、滚动部署、灰度发布、金丝雀发布

    目前有很多用于部署的技术,有的简单,有的复杂:有的得停机,有的不需要停机即可完成部署.本文的目的就是将目前常用的布署方案做一个总结. 一.蓝绿布署 Blue/Green Deployment(蓝绿部署 ...

  8. 蓝绿部署、滚动部署、灰度发布(金丝雀发布)

    传统方式 在一般情况下,升级服务器端应用,需要将应用源码或程序包上传到服务器,然后停止掉老版本服务,再启动新版本.但是这种简单的发布方式存在两个问题, (1)在新版本升级过程中,服务是暂时中断的, ( ...

  9. 蓝绿部署、滚动部署、灰度部署、金丝雀部署

    一.Blue/Green Deployment(蓝绿部署) 1.部署过程: (1)准备两个相同的应用运行环境,命名为蓝色环境.绿色环境,刚开始,蓝色环境和绿色环境都运行着相同的应用版本V1,只有绿色环 ...

  10. 蓝绿红黑灰|常用的发布方式

    1 发布之痛 相信每个程序员都曾经经历过,或正在经历过发布的痛苦,每个发布日的夜晚通常是灯火通明.在现在互联网公司较高的发布频率之下更是放大了这种痛苦,多少正值青春年华的程序员为此白了发.秃了头!让程 ...

最新文章

  1. 分布式应用解耦利器rabbitmq
  2. renameto 阻塞_打造简化版文件下载器
  3. redis stream持久化_一文了解:Redis的RDB持久化
  4. S/4HANA里通过key user tool将Extension field添加到UI上的技术实现
  5. char *a 与char a[] 的区别和char** argv与char *argv[]区别
  6. Oracle多表树型查询备忘
  7. 我写了14篇文章,总结了《具体数学》常用知识点
  8. 【PowerBuilder 9.0 使用时第一次遇到的错误 c0031】
  9. 数字化工厂-Process Simulate中的运动学定义
  10. 中国居民身份证、通行证(含香港、澳门、台湾)资料整理,含编码规则
  11. 三菱PLC特殊软元件
  12. cuda学习(5):使用cuda核函数加速warpaffine
  13. 语音信号处理(一):对声母和韵母进行录音并时域分析
  14. python——利用记忆曲线制作单词计划表
  15. 开放性:你可能没听说过的终极大挑战(开放性既是驱动探索智能的力量之一,也可能直接就是AI本身的组成部分)
  16. 关于华为交换机bpdu enable. ntdp enable. ndp enable解析
  17. Linq技术四:动态Linq技术 -- Linq.Expressions
  18. DC/DC电源输入输出滤波电容摆放位置
  19. Java【7】工具包(集合框架、函数式编程、Optional容器)
  20. 计算机与英语相关工作,职业英语--计算机类

热门文章

  1. [转自知乎]总有些人,让你找不到话题可聊
  2. 计算机名词解释 虚拟机,名词解释:什么是虚拟机
  3. css多栏布局(双栏布局、三栏布局、圣杯布局、双飞翼布局)
  4. 翻译-linux-5.1.2\Documentation\virtual\kvm\api.txt
  5. (附源码)php校园二手交易网站 毕业设计041148
  6. 集成运放——比例运算电路输入输出电压的关系
  7. win8专业版桌面ie图标不见了怎么恢复--win10专业版
  8. bash 和 sh 的一点儿区别
  9. 曝光一下阿里的工资待遇和职位级别,原来是我们肤浅啦
  10. dell服务器 指示灯_DELL服务器面板指示灯错误代码