一文带你走进CI/CD

简介: 一文带你走进CI/CD

前言:

前几天在阿里云的大咖问答板块瞎逛

遇到一个同学的问题吸引到了我:CI/CD Not Found?

我心想:什么是 CI/CD?

虽然很丢人,但咱也不能说谎不是。赶紧学习才是正道。

1.png


目录

一、CI/CD 的概述

二、CI 持续集成(Continuous Integration)

三、CD 持续交付(Continuous Delivery)

四、CD 持续部署(Continuous Deployment)

五、CI 和 CD 有什么区别?


一、CI/CD 的概述

CI/CD 是一种通过在应用开发阶段引入自动化来频繁向客户交付应用的方法。


CI/CD 的核心概念是持续集成、持续交付和持续部署。它是作为一个面向开发和运营团队的解决方案,主要针对在集成新代码时所引发的问题(也称为:“集成地狱”)。


CI/CD 可让持续自动化和持续监控贯穿于应用的整个生命周期(从集成和测试阶段,到交付和部署)。


这些关联的事务通常被统称为 CI/CD 管道,由开发和运维团队以敏捷方式协同支持。


哦!原来是这个东东。其实平时开发需求都在用集成平台,但是却不知道它背后的概念。

1.png


二、CI 持续集成(Continuous Integration)

协同开发是目前主流的开发方式,也就是多位开发人员可以同时处理同一个应用的不同模块或者功能。


但是,如果企业计划在同一天,将所有开发分支代码集成在一起,最终可能会花费很多时间和进行很多重复劳动,费事费力。因为代码冲突是难以避免的。


如果开发人员本地的环境和线上不一致的话,那么这个问题就更加复杂了。


持续集成(CI)可以帮助开发者更加方便地将代码更改合并到主分支。


一旦开发人员将改动的代码合并到主分支,系统就会通过自动构建应用,并运行不同级别的自动化测试(通常是单元测试和集成测试)来验证这些更改,确保这些更改没有对应用造成破坏。


如果自动化测试发现新代码和现有代码之间存在冲突,CI 可以更加轻松地快速修复这些错误。


三、CD 持续交付(Continuous Delivery)

CI 在完成了构建、单元测试和集成测试这些自动化流程后,持续交付可以自动把已验证的代码发布到企业自己的存储库。


持续交付旨在建立一个可随时将开发环境的功能部署到生产环境的代码库。


在持续交付过程中,每个步骤都涉及到了测试自动化和代码发布自动化。


在流程结束时,运维团队可以快速、轻松地将应用部署到生产环境中。


四、CD 持续部署(Continuous Deployment)

对于一个完整、成熟的 CI/CD 管道来说,最后的阶段是持续部署。


它是作为持续交付的延伸,持续部署可以自动将应用发布到生产环境。


实际上,持续部署意味着开发人员对应用的改动,在编写完成后的几分钟内就能及时生效(前提是它通过了自动化测试)。这更加便于运营团队持续接收和整合用户反馈。


总而言之,所有这些 CI/CD 的关联步骤,都极大地降低了应用的部署风险。


不过,由于还需要编写自动化测试以适应 CI/CD 管道中的各种测试和发布阶段,因此前期工作量还是很大的。


五、CI 和 CD 有什么区别?

CI/CD 中的“CI”始终指持续集成,它属于开发人员的自动化流程。


成功的 CI 意味着应用代码的新更改会定期构建、测试并合并到共享存储库中。


该解决方案可以解决在一次开发中有太多应用分支,从而导致相互冲突的问题。


CI/CD 中的“CD”指的是持续交付和/或持续部署,这些相关概念有时会交叉使用。两者都事关管道后续阶段的自动化,但它们有时也会单独使用,用于说明自动化程度。


持续交付(第一种CD)通常是指开发人员对应用的更改会自动进行错误测试并上传到存储库(如 GitHub 或容器注册表),然后由运维团队将其部署到实时生产环境中。


这旨在解决开发和运维团队之间可见性及沟通较差的问题。


因此,持续交付的目的就是确保尽可能减少部署新代码时所需的工作量。


持续部署(另一种“CD”)指的是自动将开发人员的更改从存储库发布到生产环境,以供客户使用。


它主要为了解决因手动流程降低应用交付速度,从而使运维团队超负荷的问题。持续部署以持续交付的优势为根基,实现了管道后续阶段的自动化。


所以,用一张图总结一下就是:

1.png

CI/CD 既可能仅指持续集成和持续交付构成的关联环节,也可以指持续集成、持续交付和持续部署这三项构成的关联环节。


更为复杂的是,有时“持续交付”也包含了持续部署流程。


归根结底,我们没必要纠结于这些语义,您只需记得 CI/CD 其实就是一个流程(通常形象地表述为管道),用于实现应用开发中的高度持续自动化和持续监控。


许多企业最开始先添加 CI,然后逐步实现交付和部署的自动化(例如作为云原生应用的一部分)。

相关文章
|
Devops jenkins Java
【devops】六、CI、CD入门操作
【devops】六、CI、CD入门操作
150 0
|
3月前
|
缓存 监控 数据可视化
利用GitLab CI/CD自动化您的软件开发流程
【10月更文挑战第10天】GitLab CI/CD 是 GitLab 内置的持续集成和持续部署工具,通过编写 .gitlab-ci.yml 文件,可以自动化构建、测试和部署应用程序的过程。本文介绍 GitLab CI/CD 的核心优势、实施步骤及在现代开发中的应用,帮助您提高开发效率和软件质量。
|
5月前
|
Kubernetes Cloud Native 开发者
基于 K8s 做应用发布的工具选择:Tekton,一颗璀璨的CI/CD新星!
【8月更文挑战第8天】在众多Kubernetes应用发布工具中,阿里巴巴为何青睐Tekton?Tekton“以应用为中心”的设计理念与阿里巴巴的技术哲学相契合,不仅关注代码构建部署,还覆盖应用全生命周期管理,完美融入阿里巴巴业务场景。Tekton提供灵活工作流定义、多平台支持及与Kubernetes生态无缝集成等功能,满足阿里巴巴复杂业务需求的同时赋予开发者更多灵活性。作为CNCF毕业项目,Tekton拥有活跃社区和不断壮大的生态系统,为阿里巴巴技术演进提供坚实基础。综上所述,阿里巴巴选择Tekton是一个深思熟虑且具前瞻性的决策。
137 0
|
监控 安全 测试技术
现在公司都在用的CI/CD框架到底是什么?
现在公司都在用的CI/CD框架到底是什么?
1528 1
|
8月前
|
监控 安全 搜索推荐
团队对CI/CD 工具的要求
选择和评估CI/CD工具的关键点包括:易用性和可定制性,需兼顾新手友好与团队个性化需求;强大的自动化能力,能处理复杂流程;良好的集成性,与各类开发工具无缝配合;开源和成本效益,开源选项常受青睐以降低成本;丰富的文档和社区支持,便于问题解决和功能利用;重视安全性,保护代码和部署安全;具备可扩展性,随团队及项目规模增长而扩展;以及提供监控和报告功能,确保及时响应构建、测试和部署的状态。这些因素有助于提升软件开发效率和质量。
105 0
|
存储 运维 监控
一文带你走进CI/CD
​ 前言: 前几天在阿里云的大咖问答板块瞎逛 遇到一个同学的问题吸引到了我:CI/CD Not Found? 我心想:什么是 CI/CD? 虽然很丢人,但咱也不能说谎不是。赶紧学习才是正道。   目录 一、CI/CD 的概述 CI/CD 是一种通过在应用开发阶段引入自动化来频繁向客户交付应用的方法。 CI/CD 的核心概念是持续集成、持续交付和持续部署。它是作为一个面向开发和运营团队的解决方案,主要针对在集成新代码时所引发的问题(也称为:“集成地狱”)。 CI/CD 可让持续自动化和持续监控贯穿于应用的整个生命周期(从集成和测试阶段,到交付和部署)。 这些关联
635 1
一文带你走进CI/CD
|
存储 jenkins 测试技术
不错,4 张图了解 CI/CD 基础~
任何商业软件项目都希望通过业务流程的自动化来迅速盈利。迭代快、发布快、更新稳定,就意味着项目能走得更远; 虽然,这个过程可以手动,但是手动克隆代码库、手动链接远程服务器、手动构建、手动运行命令等,任何一个手动的过程都意味着比自动要承受更大的出错风险!
|
Shell Linux 测试技术
Docker分享-CI/CD之路
Docker分享-CI/CD之路
115 0
|
缓存 前端开发 测试技术
Docker分享-CI/CD之路(2)
Docker分享-CI/CD之路(2)
150 0
|
敏捷开发 监控 测试技术
持续集成与部署(一):CI/CD简介
持续集成与部署(一):CI/CD简介
持续集成与部署(一):CI/CD简介