码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 6种应用部署策略对比


    一、部署策略种类

    应用发布策略或者叫部署策略(Deployment strategy),针对应用的部署形态、升级特征来划分类型,不同策略所需要的资源、技能、复杂度和面向的场景等等都有所差异。

    1.1 停机重建(Recreate)

    先停用V1版本,后在原资源上部署启用V2版本,演示如下。
    在这里插入图片描述

    1.2 滚动升级(Ramped、Rolling Update)

    V2版本实例加入集群,逐个/批替换V1版本实例,演示如下。
    在这里插入图片描述

    1.3 蓝绿部署/红黑部署(Blue/Green、Red/Black)

    先部署V2版本(绿),后接收V1版本(蓝)全部流量,演示如下。
    在这里插入图片描述

    1.4 灰度部署/金丝雀(Canary)

    V2版本接收部分流量,后接替V1版本全部流量,演示如下。
    在这里插入图片描述

    1.5 A/B测试(A/B test)

    V2版本接收特定条件(位置、浏览器等)的流量,演示如下。
    在这里插入图片描述

    1.6 影子测试(Shadow test)

    V2版本镜像A版本真实流量,后接替V1版本,演示如下。
    在这里插入图片描述

    二、部署策略对比

    发布策略新老并行不停机流量控制真流量测试用户采样资源成本回滚时长用户影响实施复杂度
    停机重建×××××低长大低
    滚动升级√√×××低长小低
    蓝绿部署
    红黑部署
    ×√×××高短中中
    灰度部署
    金丝雀
    √√√√×中短小中
    A/B测试√√√√√高短小高
    影子测试√√×√×高无无高

    三、示例说明

    前后三种(灰度、A/B、影子)分别被Google单独划分为部署策略和测试策略,这里全部作为部署策略来看待。其中的蓝绿、灰度和A/B都和流量的多少有关。蓝绿是一把全流量切换,A/B是无筛选的部分流量切换,而A/B是特定流量的切换。蓝绿,注定了需要全局充分测验之后才能接受整体切换的流量,灰度的新版本即便造成故障也只是一部分的流量,而A/B更多的在于比较不同用户(区域、浏览器版本等)针对不同版本的体验,可以用来做比对性选择,本质上是用“小白”来试验。

    举个例子,假设在全球不同区域都部署了同一个版本的集群实例,我们做版本升级的时候,肯定是逐个区域地实施。一来,把控实施进度;二来,即便故障也好及时识别和完善。这个场景下,说它是滚动升级、灰度部署和A/B都可以。时而看到一个电子商务站点,不同区域的人访问同一个页面却有所差异就是这么回事。也就是说,这几个策略,在大小实例/集群都是适用的,不用角度或者视角上表现有所差异,主要看到底目的是什么。

    四、参考材料

    • Six Strategies for Application Deployment – The New Stack
    • 应用部署和测试策略 | 云架构中心 | Google Cloud
    • 《分布式系统设计模式》系列干货:管理设计篇之"部署升级策略"_语言 & 开发_陈皓_InfoQ精选文章
  • 相关阅读:
    Sentinel微服务流量治理组件实战下
    【改造后序遍历】 98. 验证二叉搜索树
    禅道数据库异机访问,远程连接,navicat连接
    AI 律助 Alpha GPT 线上实操发布会,重磅发布!
    vue3和vue2生命周期​
    Primavera P6 Calendars 全局日历和项目日历Calendar
    LeetCode【17】电话号码的字母组合
    linux ubuntu22.04安装eDEX-UI:命令操作及系统资源负载监控大屏
    国产智多晶FPGA基于Verilog的设计开发流程
    网络基础知识点
  • 原文地址:https://blog.csdn.net/evandeng2009/article/details/125483402
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号