一.简介

在敏捷开发时,通常将服务进行拆分成不同模块,每个开发小组负责一个模块的开发,会在一天内对这个模块进行频繁的提交到仓库主干并部署到线上。CI/CD就是在开发中使用工具保证快速并稳定上线的方法,提交开发效率。

现在 jenkins 已经是常用运维工具了,所以很难体会到 CI/CD 的效果,没有进行对比。实际在最开始的时候一个技术团队中开发、测试、运维是没有太多关联的,发布模式如下:

  1. 开发进行项目代码开发、本地 PC 运行成功后将代码提交到版本 git 仓库中
  2. 开发通知运维进行项目发布,运维运行脚本将代码下载并打包构建
  3. 运维用部署脚本将成品部署到测试环境,通知测试人员进行功能测试
  4. 测试人员进行自动化功能测试,完成后通知开发可以合并到生产环境
  5. 找一天晚上运维进行生产环境的发版,测试进行功能测试

流程是没有问题的,在最开始瀑布式开发中因为 1-2 个月才发版一次这个发布流程不会出太大问题。但目前都是敏捷开发,将一个产品需求分割成多个,一天里测试环境可能要进行 10 多次迭代过程,那上面的模式会很痛苦,同时手动环境太多,也会造成人为失误。

二.分解

CI

持续集成(CONTINUOUS INTEGRATION)

在持续集成环境中,开发人员将会将代码频繁的从本地合并到主分支。每次迭代都要通过编译和自动化测试流进行验证。这样做是基于之前持续集成过程中很重视自动化测试验证结果,以保障所有的提交在合并主线之后的质量问题,对可能出现的一些问题进行预警。

需要具备哪些条件:

  1. 你的团队需要为每个新功能,代码改进,或者问题修复创建自动化测试用例。
  2. 你需要一个持续集成服务器,它可以监控代码提交情况,对每个新的提交进行自动化测试。
  3. 研发团队需要尽可能快的提交代码,至少每天一次提交。

能获得什么呢?

  1. 通过自动化测试可以提早拿到回归测试的结果,避免将一些问题提交到交付生产中
  2. 发布编译将会更加容易,因为合并之初已经将所有问题都规避了
  3. 减少工作问题切换,研发可以很快获得构建失败的消息,在开始下一个任务之前就可以很快解决。
  4. 测试成本大幅降低-你的 CI 服务器可以在几秒钟之内运行上百条测试。
  5. 你的 QA 团队花费在测试上面的时间会大幅缩短,将会更加侧重于质量文化的提升上面。

CD

持续交付(CONTINUOUS DELIVERY)

CI 很容易理解,就是持续集成。但是 CD 既可以指代码持续交付,也可理解为代码持续部署。CI 和 CD 之间有很多相似的部分,但是也有很大的区别。

CI 主要是对代码进行迭代,保证每次修改的代码新增的内容都可以通过测试操作,确保在后续基础上开发,之前的代码没问题。但这些迭代多是内部迭代,并不发到生产,不会让用户进行体验。

持续交付就是讲我们的应用发布出去的过程。这个过程可以确保我们尽可能快的实现交付,将大需求拆分多个小版本,这样随时就可以发布多个小版本让用户尽快体验,可能在发布后出现其实不适合这个产品的情况,也可以避免更多损失,及时停止开发。

需要具备什么条件?

  1. 你需要有强大的持续集成组件和足够多的测试项可以满足你代码的需求
  2. 部署需要自动化。触发是手动的,但是部署一旦开始,就不能人为干预。
  3. 你的团队可能需要接受特性开关,没有完成的功能模块不会影响到线上产品。

能收获什么?

  1. 繁琐的部署工作没有了。你的团队不在需要花费几天的时间去准备一个发布。
  2. 你可以更快的进行交付,这样就加快了与客户之间的反馈环。
  3. 轻松应对小变更,加速迭代

CI/CD

持续部署(CONTINUOUS DEPLOYMENT)

如果我们想更加深入一步的话,就是持续部署了。通过这个方式,任何修改通过了所有已有的工作流就会直接和客户见面。没有人为干预(没有一键部署按钮),只有当一个修改在工作流中构建失败才能阻止它部署到产品线。

持续部署是一个很优秀的方式,可以加速与客户的反馈循环,但是会给团队带来压力,因为不再有“发布日”了。开发人员可以专注于构建软件,他们看到他们的修改在他们完成工作后几分钟就上线了。基本上,当开发人员在主分支中合并一个提交时,这个分支将被构建、测试,如果一切顺利,则部署到生产环境中。

需要具备的条件:

  1. 研发团队测试理念比较完善。测试单元的健壮性直接决定你的交付质量。
  2. 你的文档和部署频率要保持一致。
  3. 特征标志成为发布重大变化过程的固有部分,以确保您可以与其他部门(支持,市场营销,公关…)协调。

可以获得什么?

  1. 发布频率更快,因为你不需要停下来等待发布。每一处提交都会自动触发发布流。
  2. 在小批量发布的时候,风险降低了,发现问题也可以很轻松的修复。
  3. 客户每天都可以看到我们的持续改进和提升,而不是每个月或者每季度,或者每年。

三.总结

如前所述,您可以采用持续集成,持续交付和持续部署。你怎么做取决于你的需求和你的业务情况。

如果你刚刚开始一个项目,并且还没有客户,那么你就可以去创建这些工作流,最好是将这三个方面都实现,并且在你的项目迭代和需求增长中同时迭代它们。如果您已经有一个生产项目,那么您可以一步一步地分阶段去实现他们。

持续部署CI/CD的更多相关文章

  1. GitLab私有化部署 - CI/CD - 持续集成/交付/部署 - 源代码托管 & 自动化部署

    预期目标 源代码管理 借助GitLab实现源代码托管,私有化部署版本,创建项目,创建用户组,分配权限,项目的签入/牵出等. 自动化部署 源代码产生变更时(如签入),自动化编译并发布到指定服务器中部署, ...

  2. 持续集成、持续交付(CI/CD)开篇,先来唠唠嗑

    前言 现在稍微有点规模的系统,很多都是采用分布式/微服务架构,将一个大系统拆分为很多个功能模块进行开发.测试.发布.管理等,如果全部流程都采用人工的形式进行的话,效率肯定是超级不高效滴.而且现在很多项 ...

  3. 持续集成CI/CD

    Gitlab+kubernetes+docker+jenkins+harbor搭建持续交付系统 http://blog.chenmiao.cf/2016/12/28/gitlab+kubernetes ...

  4. Jenkins+GitLab+Sonarqube+Shell持续集成CI/CD

    1.部署GitLab 2.部署Jenkins 3.Sonar代码审计 4.参数化构建 5.git参数化构建

  5. CI / CD /CD 持续集成 持续交付 持续部署

    CI / CD /CD 持续集成 持续交付 持续部署 CI CD 是啥?干了啥? CI continuous integration 持续集成 CD continuous delivery 持续交付 ...

  6. CI Weekly #7 | Instgram/Quora 等大公司如何做持续部署?

    终于,你们期待的 flow.ci iOS 项目持续集成 开始公测了.在这几个工作日, flow.ci 做了些许「功能优化」与「问题修复」,性能和体验都在持续优化中.比如: iOS 快速入门文档更新: ...

  7. .NET Core微服务之基于Jenkins+Docker实现持续部署(Part 1)

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 一.CI, CD 与Jenkins 互联网软件的开发和发布,已经形成了一套标准流程,最重要的组成部分就是持续集成(Continuous i ...

  8. 什么是 CI/CD?

    什么是 CI/CD? 在软件开发中经常会提到持续集成Continuous Integration(CI)和持续交付Continuous Delivery(CD)这几个术语.但它们真正的意思是什么呢? ...

  9. 什么是 CI/CD?(翻译)

    CI/CD是什么? 原文:https://opensource.com/article/18/8/what-cicd 在谈论软件开发时,经常会提到持续集成Continuous Integration( ...

随机推荐

  1. Python基础(slice切片)

    l = ['傻狗1','傻狗2','傻狗3','傻狗4','傻狗5','傻狗6'] print(l[0:3])#['傻狗1', '傻狗2', '傻狗3'] numbers = list(range(1 ...

  2. 菜鸡的Java笔记 - java 访问控制权限

    java中四种访问控制权限的使用                内容            在java里面一共定义有四个权限,按照由小到大的顺序:private<defaule<prote ...

  3. Linux下Zabbix5.0 LTS添加MySQL监控,实现邮件报警并执行预处理操作

    依据前文:Linux下Zabbix5.0 LTS监控基础原理及安装部署(图文教程) 环境,继续添加MySQL应用集. 第一部分:添加Zabbix自带的MySQL应用集. 在ZabbixClient-0 ...

  4. [loj6278]数列分块入门2

    做法1 以$K$为块大小分块,并对每一个块再维护一个排序后的结果,预处理复杂度为$o(n\log K )$ 区间修改时将整块打上标记,散块暴力修改并归并排序,单次复杂度为$o(\frac{n}{K}+ ...

  5. 3、使用ListOperations操作redis(List列表)

    文章来源:https://www.cnblogs.com/shiguotao-com/p/10560354.html 方法 c参数 s说明   List<V> range(K key, l ...

  6. 【AWS】使用X-Ray做AWS云上全链路追踪监控系统

    功能 AWS X-Ray 是一项服务,收集应用程序所请求的相关数据,并提供用于查看.筛选和获取数据洞察力的工具,以确定问题和发现优化的机会. 对于任何被跟踪的对您应用程序的请求,不仅可以查看请求和响应 ...

  7. 洛谷 P2481 [SDOI2010]代码拍卖会(背包+隔板法)

    题面传送门 题意: 给出 \(n,p\),求有多少 \(n\) 位数 \(X=a_1a_2a_3\dots a_n\) 满足: 该 \(n\) 位数不含前导零 \(a_i \leq a_{i+1}\) ...

  8. 洛谷 P5332 - [JSOI2019]精准预测(2-SAT+bitset+分块处理)

    洛谷题面传送门 七月份(7.31)做的题了,题解到现在才补,不愧是 tzc 首先不难发现题目中涉及的变量都是布尔型变量,因此可以考虑 2-SAT,具体来说,我们将每个人在每个时刻的可能的状态表示出来. ...

  9. Codeforces 1089I - Interval-Free Permutations(析合树计数)

    Codeforces 题面传送门 & 洛谷题面传送门 首先题目中涉及排列的 interval,因此可以想到析合树.由于本蒟蒻太菜了以至于没有听过这种神仙黑科技,因此简单介绍一下这种数据结构:我 ...

  10. DirectX12 3D 游戏开发与实战第十二章内容

    12.几何着色器 如果不启用曲面细分,那么几何着色器这个可选阶段将会在位于顶点着色器和像素着色器之间.顶点着色器以顶点作为输入数据,而几何着色器以完整的图元为输入数据.与顶点着色器不同的是,顶点着色器 ...