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

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

时间:2023-09-04 13:33:29浏览次数:39  
标签:测试 部署 金丝雀 蓝绿 发布 灰度 版本

蓝绿发布(Blue-Green Deployment)

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

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

优缺点

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

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

image

image

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

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

不停机旧版本,部署新版本,高比例流量(例如:95%)走旧版本,低比例流量(例如:5%)切换到新版本,通过监控观察无问题,逐步扩大范围,最终把所有流量都迁移到新版本上。属无损发布
在软件开发中,灰度测试通常涉及将新功能或更新推送到一小部分用户,例如5%或10%的用户。
这些用户将能够使用新功能或更新,而其他用户则不会看到它们。
通过监视这些用户的反馈和行为,开发人员可以评估新功能或更新的效果,并识别任何问题或错误。

在Java中,可以使用一些工具来实现灰度测试,例如FeatureToggle和LaunchDarkly。
这些工具可以帮助开发人员轻松地控制新功能或更新的推出,并监视用户反馈和行为。

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

A/B测试

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

滚动发布(Rolling Release)

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

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

image

红黑部署(Red-Black Deployment)

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

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

标签:测试,部署,金丝雀,蓝绿,发布,灰度,版本
From: https://www.cnblogs.com/vipsoft/p/17676569.html

相关文章

  • 发布!用友跨国企业全球税务管理解决方案助力中企全球化
    2023年8月19日在上海国家会展中心,毕马威全球税务合规与转型服务主管合伙人闫晓光、汤森路透大中华区营销负责人吴莉、用友网络高级副总裁杜宇、用友网络德国总经理林楠、用友网络税务云事业部总经理陈飞及企业的高管、技术大咖、专家学者、投资人、媒体等众多商业领袖一起见证......
  • Ziya-LLaMA-13B 模型在GPU 上部署
    Ziya-LLaMA-13B模型在GPU上部署Ziya-LLaMA-13B是IDEA-CCNL基于LLaMa的130亿参数的大规模预训练模型,具备翻译,编程,文本分类,信息抽取,摘要,文案生成,常识问答和数学计算等能力。目前姜子牙通用大模型已完成大规模预训练、多任务有监督微调和人类反馈学习三阶段的训练过程。1.部署准......
  • rabbitmq发布确认高级
    前言在之前的发布确认中,生产者发送消息到mq中,消费者在从mq中取出消息满足持久化的.发布确认是一个保证RabbitMQ可靠性的一个机制  保证生产者将信息成功的发送到RabbitMQ的server端了,那么broker就会回一个确认,如果没有收到或者收到拒绝信息,那么说明可能网络不好没有发送成......
  • 全开源风车im源码(前端uniapp可发布H5及app/后端java含视频搭建教程)
    互联网彻底改变了我们的沟通方式,电子邮件是迄今为止采用最快的通信形式。不到二十年前,还没有多少人听说过它。现在,我们中的许多人都用电子邮件而不是写信,甚至打电话给别人,世界各地的人们每天发送数十亿封电子邮件。源码:ms.jstxym.top但有时甚至电子邮件也不够快。您可能不知道您......
  • 微服务发布到docker后,一直重启Restarting (1) 2 seconds ago.
     使用dockerlogs加容器的ID命令,就可以查看该容器的启动的具体信息了。dockerlogsc59ba37a2508看一下日志:根据具体的报错信息来处理就可以了。  ......
  • VMware NSX Advanced Load Balancer (NSX ALB) 30.1.1 发布 - 多云负载均衡平台
    VMwareNSXAdvancedLoadBalancer(NSXALB)30.1.1发布-多云负载均衡平台请访问原文链接:https://sysin.org/blog/vmware-nsx-alb-30/,查看最新版。原创作品,转载请保留出处。作者主页:sysin.org负载均衡平台NSXAdvancedLoadBalancerNSXAdvancedLoadBalancer(Avi)......
  • Ant Design 5.8.6 发布,企业级 UI 设计语言和 React 实现
    AntDesign5.8.6发布,企业级UI设计语言和React实现来源:OSCHINA编辑: 白开水不加糖2023-09-0310:31:02 0AntDesign 5.8.6 现已发布,主要变化如下: 针对CSSInJS加载styles大小进行了优化。Notification和Message组件只有在展示时才会插入对......
  • QQ for Linux 正式发布 3.2.0
    QQforLinux正式发布3.2.0来源:OSCHINA编辑: 局2023-09-0215:57:28 8Linux版QQ正式发布了3.2.0。QQLinux版3.2.0(2023.09.01)1、新增夜间模式并支持跟随系统,享受更沉浸的聊天体验;2、新增QQ截图能力,快捷方便,提升办公效率;3、新增群应用功能,图片......
  • 手把手教你在虚拟机中部署K8S集群二
    我们在:  手把手教你在虚拟机中部署Kubernetes集群(K8S)_ZeroMaster的博客知道基本的部署方式,但是上面还是有一些问题,比如一些服务启动有问题。下面有一个更详细的方式。实测可用。一、环境规划Kubernetes集群大致分为两类:一主多从和多主多从。(1)一主多从(单master):一个Master节......
  • 发布部署
    上线上线:指你的团队从源码管理库中获取服务代码某个版本的快照,并用它处理线上流量的过程。我认为整个上线过程由四个不同的专门的小流程组成:构建(build)、测试、部署和发布。得益于云基础架构、容器、编配框架的技术进步以及流程改进,如twelve-factor、持续集成和持续交付,执......