发布策略:蓝绿部署、金丝雀发布(灰度发布)、AB测试、滚动发布、红黑部署的概念与区别

简介: 发布策略:蓝绿部署、金丝雀发布(灰度发布)、AB测试、滚动发布、红黑部署的概念与区别

蓝绿发布(Blue-Green Deployment)

蓝绿发布提供了一种零宕机的部署方式。不停老版本,部署新版本进行测试,确认OK,将流量切到新版本,然后老版本同时也升级到新版本。始终有两个版本同时在线,有问题可以快速切换。

蓝绿部署中,一共有两套系统:

  • 一套是正在提供服务系统,标记为“绿色”;
  • 另一套是准备发布的系统,标记为“蓝色”。

优缺点

  • 优点:新版本升级和老版本回滚迅速。用户可以灵活控制流量走向
  • 缺点:成本较高,需要部署两套环境(蓝/绿)

比如日常运行时,需要10台服务器支撑业务,那么使用蓝绿部署,你就需要购置二十台服务器。

1)、蓝绿部署的原理

蓝绿部署的基本原理是在两个独立的生产环境之间交替进行部署和切换。这两个环境通常被称为“蓝色环境”和“绿色环境”。在初始情况下,通常只有一个环境(例如蓝色环境)在处理生产流量。当新版本的应用程序准备就绪后,它会被部署到未处理生产流量的环境(例如绿色环境)中进行测试。一旦测试通过,生产流量就会从蓝色环境切换到绿色环境。如果新版本出现问题,可以快速切换回蓝色环境,从而确保服务的连续性。

2)、蓝绿部署的步骤
  1. 准备两个环境:首先,需要准备两个几乎相同的生产环境,即蓝色环境和绿色环境。这两个环境应该具有相同的配置、依赖和基础设施,以确保应用程序在两个环境中都能正常运行。
  2. 部署新版本:将新版本的应用程序部署到绿色环境中。在部署过程中,需要确保新版本与当前蓝色环境中的版本兼容,并且不会破坏现有的数据或配置。
  3. 测试新版本:在绿色环境中进行充分的测试,包括功能测试、性能测试和安全性测试等。测试的目的是确保新版本运行正常,没有重大缺陷或漏洞。
  4. 切换流量:一旦确定绿色环境中的新版本没有问题,就可以将生产流量从蓝色环境切换到绿色环境。这个过程通常是通过更新负载均衡器或DNS配置来实现的。切换流量时,用户通常不会感知到停机,从而实现了连续服务。
  5. 监控和验证:在绿色环境中运行一段时间后,需要监控其表现以确保一切正常。如果发现任何问题或异常,可以迅速切换回蓝色环境,以确保服务的稳定性和可靠性。
  6. 重复过程:在下一次部署时,重复上述过程。此时,绿色环境将成为旧版本,而蓝色环境将部署新版本并进行测试。通过这种方式,可以不断迭代和更新应用程序,同时保持服务的连续性和稳定性。
3)、蓝绿部署的优势
  1. 零停机时间:通过蓝绿部署,可以在不中断服务的情况下进行版本切换,从而实现了零停机时间。这有助于提高用户体验和系统的可用性。
  2. 快速回滚:如果新版本出现问题,可以迅速切换回旧版本,从而降低了风险。这种快速回滚的能力有助于确保服务的稳定性和可靠性。
  3. 易于进行版本切换:蓝绿部署允许两个环境交错使用,新旧版本可以快速切换。这提供了一个平滑的过渡期,有助于减少部署过程中的不确定性和风险。
  4. 提高发布效率:通过自动化部署工具,如Jenkins、Spinnaker等,可以支持蓝绿部署的连续集成和持续部署流程。这有助于加快发布速度,提高发布效率。

金丝雀发布/灰度发布(Canary Release)

灰度发布 Gray Release(又名金丝雀发布 Canary Release)

金丝雀发布有一个有趣的小故事,被称为「金丝雀在矿井」。这个故事用来形象地描述金丝雀发布策略的概念。

故事背景是在过去的煤矿开采中,矿工们面临着一种危险的情况,即有毒气体的积累。由于无法直接检测到这些气体,矿工们需要一种警报机制来提醒他们是否面临危险。他们找到了一种解决方案:带上一只小小的金丝雀。

矿工们将金丝雀放入煤矿,如果气体达到了危险的水平,金丝雀会首先受到影响并死亡,从而警示矿工们立即离开矿井以避免危险。这种警报系统保护了矿工的生命安全。

不停机旧版本,部署新版本,高比例流量(例如:95%)走旧版本,低比例流量(例如:5%)切换到新版本,通过监控观察无问题,逐步扩大范围,最终把所有流量都迁移到新版本上。属无损发布

在软件开发中,灰度测试通常涉及将新功能或更新推送到一小部分用户,例如5%或10%的用户。

这些用户将能够使用新功能或更新,而其他用户则不会看到它们。

通过监视这些用户的反馈和行为,开发人员可以评估新功能或更新的效果,并识别任何问题或错误。

在Java中,可以使用一些工具来实现灰度测试,例如FeatureToggle和LaunchDarkly。

这些工具可以帮助开发人员轻松地控制新功能或更新的推出,并监视用户反馈和行为。

  • 优点:灵活简单,不需要用户标记驱动。安全性高,新版本如果出现问题,只会发生在低比例的流量上
  • 缺点:成本较高,需要部署稳定/灰度两套环境

A/B测试

首先需要明确的是,A/B测试和蓝绿部署以及金丝雀,完全是两回事。

蓝绿部署和金丝雀是发布策略,目标是确保新上线的系统稳定,关注的是新系统的BUG、隐患。

A/B测试是效果测试,同一时间有多个版本的服务对外服务,这些服务都是经过足够测试,达到了上线标准的服务,有差异但是没有新旧之分(它们上线时可能采用了蓝绿部署的方式)。

A/B测试关注的是不同版本的服务的实际效果,譬如说转化率、订单情况等。

A/B测试时,线上同时运行多个版本的服务,这些服务通常会有一些体验上的差异,譬如说页面样式、颜色、操作流程不同。相关人员通过分析各个版本服务的实际效果,选出效果最好的版本。

在A/B测试中,需要能够控制流量的分配,譬如说,为A版本分配10%的流量,为B版本分配10%的流量,为C版本分配80%的流量。

滚动发布(Rolling Release)

每次只升级一个或多个服务,通过观察无问题,不断执行这个过程,直到集群中的全部旧版本升级到新版本。属有损发布

K8S 默认采用了滚动发布

  • 优点:成本较低,只需要部署一套环境。出现问题影响范围,只限于发生在若干台正在滚动发布的服务上
  • 缺点:停止旧版本的过程中,无法精确计算旧版本是否已经完成它正在执行的工作,需要靠业务自身去判断。旧版本不保留,一旦全部升级完毕后才发现问题,无法快速回滚,必须重新降级部署。发布和回滚需要较长的时间周期

红黑部署(Red-Black Deployment)

这是Netflix采用的部署手段,Netflix的主要基础设施是在AWS上,所以它利用AWS的特性,在部署新的版本时,通过AutoScaling Group用包含新版本应用的AMI的LaunchConfiguration创建新的服务器。测试不通过,找到问题原因后,直接干掉新生成的服务器以及Autoscaling Group就可以,测试通过,则将ELB指向新的服务器集群,然后销毁掉旧的服务器集群以及AutoScaling Group。

红黑部署的好处是服务始终在线,同时采用不可变部署的方式,也不像蓝绿部署一样得保持冗余的服务始终在线。

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值