当前位置:首页 > 科技  > 软件

如何正确使用上线部署,泳道、预发布到底如何理解?

来源: 责编: 时间:2024-07-03 10:07:32 237观看
导读一、背景如今互联网,随着业务需求迭代快速,同一个服务可能存在多个同时开发和测试的功能,容易发生资源抢占分支互相冲突影响的问题,降低开发测试效率。同时微服务架构下,一个功能可能需要依赖多个服务。在测试其中一个服务

一、背景

如今互联网,随着业务需求迭代快速,同一个服务可能存在多个同时开发和测试的功能,容易发生资源抢占分支互相冲突影响的问题,降低开发测试效率。i3i28资讯网——每日最新资讯28at.com

同时微服务架构下,一个功能可能需要依赖多个服务。在测试其中一个服务的改动时,如果依赖的服务发生了改动或者故障,也会影响这个功能的测试。i3i28资讯网——每日最新资讯28at.com

......i3i28资讯网——每日最新资讯28at.com

以上种种问题情况,都会导致服务从测试到线上正式环境的环境差异性较大。i3i28资讯网——每日最新资讯28at.com

规范上线部署流程,通过对环境的隔离来剥离耦合型风险,便于问题暴露及快速解决。i3i28资讯网——每日最新资讯28at.com

图片图片i3i28资讯网——每日最新资讯28at.com

二、预发布环境

2.1 介绍

i3i28资讯网——每日最新资讯28at.com

预发布环境 Staging,即线上环境、正式生产环境。i3i28资讯网——每日最新资讯28at.com

为避免因为测试环境和线上环境的差异性等带来的缺陷漏测而设立的一套环境。其配置等基本和线上一致,只是预发布环境web服务器不在线上集成服务器范围之内,为单独的一台机器。i3i28资讯网——每日最新资讯28at.com

i3i28资讯网——每日最新资讯28at.com

预发布环境 也算是线上/正式生产环境,只是其具有特殊的隔离特性(包括网络/数据/用户/行为等),不能被线上用户访问。i3i28资讯网——每日最新资讯28at.com

2.2 预发布环境 vs 灰度环境


i3i28资讯网——每日最新资讯28at.com

预发布环境 i3i28资讯网——每日最新资讯28at.com

灰度环境i3i28资讯网——每日最新资讯28at.com

目标i3i28资讯网——每日最新资讯28at.com

正式发布之前进行最后的测试和准备工作,确保产品稳定可靠i3i28资讯网——每日最新资讯28at.com

在产品正式发布之前对用户进行试用,收集反馈和观察市场反应i3i28资讯网——每日最新资讯28at.com

范围i3i28资讯网——每日最新资讯28at.com

涉及整个产品,所有功能和特性都会进行全面测试i3i28资讯网——每日最新资讯28at.com

仅涉及一小部分用户,为了控制风险和规模可控i3i28资讯网——每日最新资讯28at.com

时间点i3i28资讯网——每日最新资讯28at.com

预发布通常在正式发布之前的最后阶段进行,通常会有一个明确的时间表i3i28资讯网——每日最新资讯28at.com

灰度发布在预发布之后,但在正式发布之前的任何时间进行,其持续时间可以根据反馈和调整的需要而定i3i28资讯网——每日最新资讯28at.com

网络i3i28资讯网——每日最新资讯28at.com

与生产隔离i3i28资讯网——每日最新资讯28at.com

与生产一致i3i28资讯网——每日最新资讯28at.com

隔离性i3i28资讯网——每日最新资讯28at.com

真实用户无法访问i3i28资讯网——每日最新资讯28at.com

真实用户可访问i3i28资讯网——每日最新资讯28at.com

2.3 变更操作

i3i28资讯网——每日最新资讯28at.com

i3i28资讯网——每日最新资讯28at.com

Q:如果新版本程序需要更改表结构等(eg. 加个表字段),那么,部署到预发布环境时也需要更改表字段,这个可能会影响线上环境程序代码的运行,如何解决?i3i28资讯网——每日最新资讯28at.com

i3i28资讯网——每日最新资讯28at.com

i3i28资讯网——每日最新资讯28at.com

图片图片i3i28资讯网——每日最新资讯28at.com

1)把预发布环境使用的数据库切换为测试环境使用的数据库;i3i28资讯网——每日最新资讯28at.com

2)根据实际部署过程,如果有必要,可有针对性的测试下数据库的变更是否会影响线上当前代码程序的运行;i3i28资讯网——每日最新资讯28at.com

3)把新代码部署到预发布环境,测试程序是否正常运行;i3i28资讯网——每日最新资讯28at.com

4)预发布测试完毕,如果没问题,先上线数据库(即在正式环境执行对应的数据库变更操作);i3i28资讯网——每日最新资讯28at.com

5)把预发布环境连接的数据库切换为线上环境使用的数据库,再次进行预发布环境的测试;i3i28资讯网——每日最新资讯28at.com

6)如果预发布环境测试通过,则把预发布环境的代码部署到线上生产环境。i3i28资讯网——每日最新资讯28at.com

三、多泳道部署

3.1 介绍

多泳道部署(Multi-lane Deployment)是一种部署策略。i3i28资讯网——每日最新资讯28at.com

当指定某泳道发布服务时,发布系统会为该服务的实例打上相应的泳道标记,服务注册和发现模块就能知道同一服务的不同实例所属的泳道。i3i28资讯网——每日最新资讯28at.com

i3i28资讯网——每日最新资讯28at.com

图片图片i3i28资讯网——每日最新资讯28at.com

所谓泳道,可以理解为多个并行且相互隔离的调用链,彼此调用互不影响,就如同泳池里的泳道一样。这种策略可以提高系统的可用性和容错性,因为如果一个泳道出现问题,其他泳道仍然可以正常运行。i3i28资讯网——每日最新资讯28at.com

除了创建出来的泳道之外,还会存有一条默认的主干道,为各个服务提供默认实例,可以将其理解为常规的、常备的测试环境。除了创建的泳道外,还会存在一条默认的主干道,提供各个服务的默认实例,可以理解为常规、常备的测试环境。i3i28资讯网——每日最新资讯28at.com

i3i28资讯网——每日最新资讯28at.com

3.2 端到端的统一

1)在服务 A 需对服务 B 进行访问之时,服务 A 会率先于服务发现模块当中获取服务 B 实例的地址。鉴于服务 A 在请求中添加了 t2 泳道的标识,此时服务发现模块将会从服务 B 处于 t2 泳道的实例之中选取其一进行返回,随后服务 A 便可直接对相应实例予以访问。i3i28资讯网——每日最新资讯28at.com

2)移动端和 web 端团队需要配合做相应的改造。测试时,移动端和 web 端的测试人员能够自行切换至指定泳道,切换完毕后,所有发送至服务端的请求都会带上相应的泳道标记,这样泳道测试就实现了端到端统一。i3i28资讯网——每日最新资讯28at.com

图片图片i3i28资讯网——每日最新资讯28at.com

泳道 主要解决的问题:i3i28资讯网——每日最新资讯28at.com

  • 解决资源抢占,提高研发效率
  • 保证测试环境的稳定性

i3i28资讯网——每日最新资讯28at.com

3.3 实现思路

实现多泳道部署,主要思路包括以下几点:i3i28资讯网——每日最新资讯28at.com

1、环境准备i3i28资讯网——每日最新资讯28at.com

    首先,需要准备多个独立的环境,这些环境可以是物理服务器,也可以是虚拟机或容器。不同的需求需要隔离级别不同,如果多环境共用底层数据,则代码中使用域名配置数据库,由 DNS 服务指向同一套数据库。i3i28资讯网——每日最新资讯28at.com

    多数情况下,泳道还是采用的底层共用数据存储,好处是每次新创建分支用不到不用再创建数据库和同步数据,大大提高了环境申请和销毁效率。对于自动化测试等需要数据隔离的,我们则另外部署一套全链路环境。i3i28资讯网——每日最新资讯28at.com

2、配置管理i3i28资讯网——每日最新资讯28at.com

    每个泳道可能需要不同的配置,例如数据库连接字符串、第三方服务的API密钥等。你需要一个配置管理系统来管理这些配置,并确保它们在部署时被正确地应用到每个泳道。i3i28资讯网——每日最新资讯28at.com

    逻辑结构主要分为主泳道和分支泳道i3i28资讯网——每日最新资讯28at.com

主泳道部署全链路稳定代码,作为公共环境,承载其他环境缺省服务,保证请求链路通畅。i3i28资讯网——每日最新资讯28at.com

分支泳道只需部署改动或增量服务,未改动服务使用主泳道中服务,减少公共服务的维护成本,提高使用效率等。i3i28资讯网——每日最新资讯28at.com

3、部署策略i3i28资讯网——每日最新资讯28at.com

    你需要决定如何将应用程序部署到各个泳道。你可以选择一次部署到所有泳道,也可以选择逐个部署。i3i28资讯网——每日最新资讯28at.com

    逐个部署可以降低风险,因为如果新版本有问题,你可以在部署到所有泳道之前发现并修复它。i3i28资讯网——每日最新资讯28at.com

4、流量管理i3i28资讯网——每日最新资讯28at.com

    你需要一个负载均衡器或类似的工具来管理流量,将请求分发到各个泳道。你可以根据各种策略来分发流量,例如轮询、最少连接数、响应时间等。i3i28资讯网——每日最新资讯28at.com

    网关层负责环境识别与环境标识注入,通过测试域名隔离不同环境,RPC 层负责服务发现与选择,环境标识透传等。i3i28资讯网——每日最新资讯28at.com

5、监控和故障恢复i3i28资讯网——每日最新资讯28at.com

    你需要监控每个泳道的性能和健康状况,并在检测到问题时自动或手动切换到其他泳道。i3i28资讯网——每日最新资讯28at.com

四、总结

多泳道建设是一种高效、灵活的开发模式,尤其适用于复杂项目和跨部门协作场景。通过合理划分泳道、优化资源分配和加强团队协作,我们可以显著提高软件交付速度和质量。i3i28资讯网——每日最新资讯28at.com

在未来软件开发中,多泳道建设将继续发挥重要作用。希望本文能为你提供有益的参考和启示。i3i28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-98410-0.html如何正确使用上线部署,泳道、预发布到底如何理解?

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 11个高可用设计实战技巧,轻松应对大厂面试

下一篇: 我们一起聊聊如何编写一个 Java memcached 客户端

标签:
  • 热门焦点
  • MIX Fold3包装盒泄露 新机本月登场

    小米的全新折叠屏旗舰MIX Fold3将于本月发布,近日该机的真机包装盒在网上泄露。从图上来看,新的MIX Fold3包装盒在外观设计方面延续了之前的方案,变化不大,这也是目前小米旗舰
  • JavaScript 混淆及反混淆代码工具

    介绍在我们开始学习反混淆之前,我们首先要了解一下代码混淆。如果不了解代码是如何混淆的,我们可能无法成功对代码进行反混淆,尤其是使用自定义混淆器对其进行混淆时。什么是混
  • CSS单标签实现转转logo

    转转品牌升级后更新了全新的Logo,今天我们用纯CSS来实现转转的新Logo,为了有一定的挑战性,这里我们只使用一个标签实现,将最大化的使用CSS能力完成Logo的绘制与动画效果。新logo
  • 如何使用JavaScript创建一只图像放大镜?

    译者 | 布加迪审校 | 重楼如果您曾经浏览过购物网站,可能遇到过图像放大功能。它可以让您放大图像的特定区域,以便浏览。结合这个小小的重要功能可以大大改善您网站的用户体验
  • 19个 JavaScript 单行代码技巧,让你看起来像个专业人士

    今天这篇文章跟大家分享18个JS单行代码,你只需花几分钟时间,即可帮助您了解一些您可能不知道的 JS 知识,如果您已经知道了,就当作复习一下,古人云,温故而知新嘛。现在,我们就开始今
  • 这款新兴工具平台,让你的电脑效率翻倍

    随着信息技术的发展,我们获取信息的渠道越来越多,但是处理信息的效率却成为一个瓶颈。于是各种工具应运而生,都在争相解决我们的工作效率问题。今天我要给大家介绍一款效率
  • 本地生活这块肥肉,拼多多也想吃一口

    出品/壹览商业 作者/李彦编辑/木鱼拼多多也看上本地生活这块蛋糕了。近期,拼多多在App首页“充值中心”入口上线了本机生活界面。壹览商业发现,该界面目前主要
  • OPPO、vivo、小米等国内厂商Q2在印度智能手机市场份额依旧高达55%

    7月20日消息,据外媒报道,研究机构的报告显示,在全球智能手机出货量同比仍在下滑的大背景下,印度这一有潜力的市场也未能幸免,出货量同比也有下滑,多家厂
  • iQOO Neo8系列或定档5月23日:首发天玑9200+ 安卓跑分王者

    去年10月,iQOO推出了iQOO Neo7系列机型,不仅搭载了天玑9000+,而且是同价位唯一一款天玑9000+直屏旗舰,一经上市便受到了用户的广泛关注。在时隔半年后,
Top