CICD(3)-常见代码部署发布方式

概述

随着互联网的发展和 IT 基础设施的进步,软件开发的最大变化之一就是部署的频率。
产品团队越来越重视更早地(且更频繁地)将正式发布的产品部署到生产环境中。几个
月或几年的发布周期正变得越来越少——特别是在那些纯粹的构建和提供软件产品服务
的公司或机构。

在当今的 IT 软件服务行业,使用面向服务的体系结构和微服务架构方法,开发人员
可以设计模块化的代码。这使得他们可以同时将更改写入和部署到整个项目的代码的
不同部分。缩短产品的部署周期的好处是显而易见的:

  • 新产品更快的进入市场
  • 客户在更短时间内得到产品的价值
  • 客户的反馈将会更快的回流到产品组,这意味着开发团队可以更快的迭代产品
    和修复 BUG
  • 还可以提升开发人员的战斗力和幸福感

然而,这种快速部署的转变也为运营团队或 DevOps 团队带来了新的挑战。对于
更频繁的部署,部署的代码更有可能对站点可靠性或客户体验产生负面影响。这就
是为什么开发部署代码的策略来最小化产品和客户的风险是非常重要的。

一. 当前软件应用面临的挑战

当前的应用程序通常是分布式的和基于云的。它们可以弹性地伸缩以满足需求,并且
几乎都是部署与高可用架构的应用,由于高度可用的体系结构,在产生故障时,其更
容易快速恢复。

为满足如今的消费者和客户,这些应用程序几乎总是有频繁的更新部署。例如,一个
移动应用程序或一个消费者 web 站点可能在一个月内经历多次更改。有些甚至可以
一天多次部署到生产环境中。

整个开发项目中需要移动的部件(模块)数量的增加意味着出现问题的可能性更大。随
着多个开发团队在整个代码库中进行更改,当一个问题不可避免地发生时,很难确定
问题的根本原因。

由于消费者和客户的需求变化,产品(某个版本)的生命周期也必须尽量的缩短,在频
繁部署和迭代的过程中,涉及多个开发团队的协作和运维的代码发布维护。这种快速
迭代和发布的过程必须不出任何差错,出错后将比传统的部署方式更难发现问题。这
时候就需要开发代码持续部署集成和持续交付的工具,而随之产生了 CI/CD 的概念。

为了应对这些挑战,应用程序开发团队和基础设施团队应该设计并采用适合其产品的
部署策略。下面就介绍比较常见的代码部署方式。

二. 比较受欢迎的部署方式介绍

2.1 Big Bang 部署方式

Big B

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值