CI/CD相关概念学习

文章目录

  • CI/CD相关概念学习
    • 前言
    • CI/CD相关概念介绍
      • 集成地狱
      • 持续集成
      • 持续交付
      • 持续部署
      • Devops
    • CI/CD相关应用介绍
      • Jenkins
      • Tekton Pipelines
      • Spinnaker
      • Travis CI
      • GoCD

CI/CD相关概念学习

image-20231117174806575

前言

本文主要是介绍一些 CI/CD 相关的概念,通过阅读本文你将快速了解 CI/CD 是什么、CI/CD的作用、以及DevOps与 CI/CD 的关系。与此同时,你也将了解与 CI/CD 相关的一些应用,当然本文着重是概念介绍,关于 CI/CD 应用的使用介绍到时候会写在另外一篇文章中,敬请期待(●’◡’●)
PS:由于我也是第一次接触 CI/CD 这些概念,个人理解上可能存在一定的不恰当,如果您发现了,还请即时告知博主,万分感谢

CI/CD相关概念介绍

  • CI/CD是什么意思

    CI/CD 是一种通过在应用开发阶段引入自动化来频繁向客户交付应用的方法。CI/CD 的核心概念是持续集成、持续交付和持续部署。作为一种面向开发和运维团队的解决方案,CI/CD 主要针对在集成新代码时所引发的问题(亦称:“集成地狱”)。

    个人理解:CI/CD 就是一种软件开发方式,目标是频繁利用自动化脚本提高集成、部署效率

集成地狱

  • 什么是集成地狱

    集成地狱(Inherit Hell)是一个专业性的术语,用于描述在软件开发中,由于集成过程的复杂性和困难而导致的问题。

    集成炼狱通常发生在大型项目中,涉及多个团队和多个代码库的情况下。在这种情况下,各个团队独立开发和测试不同的功能模块,然后需要将它们集成到一个统一的整体中。这个集成过程可能会面临各种挑战,例如:

    1. 版本冲突:不同的团队可能使用不同的技术栈和依赖库,导致版本冲突和兼容性问题。
    2. API 不稳定:在开发过程中,API 可能会频繁变动,导致其他团队的代码无法正常工作。
    3. 缺乏一致性:由于开发团队的独立性,代码风格、命名规范和工程结构可能不一致,导致集成时出现问题。
    4. 集成测试问题:由于集成过程的复杂性,很难进行全面和完整的集成测试,导致潜在的问题无法被及时发现和解决。
    5. 缺乏自动化:如果集成过程需要手动操作和人工干预,将会增加出错的可能性,延长交付时间。

    ……

    以上这些集成过程中遇到的种种问题,都可以统一称之为集成地狱,集成地狱常常会导致开发周期延长、软件质量下降、项目进度滞后以及团队之间的协作问题。为了避免集成炼狱,团队可以采取一些措施,例如:

    1. 频繁集成:团队应该频繁地进行集成,以尽早发现和解决集成问题。
    2. 自动化集成:使用自动化构建、测试和部署工具,减少人为错误和提高效率。
    3. 规范和标准化:制定统一的编码规范、API设计规范和工程结构,以确保团队之间的一致性。
    4. 协作和沟通:加强团队之间的沟通和协作,及时解决集成问题和冲突。

    ……
    其中 CI/CD 就是一种解决集成地狱的有效措施

持续集成

  • 什么是持续集成

    持续集成(Continuous Integration,简称 CI)是一种软件开发实践,旨在通过频繁地将代码变更集成到共享存储库中,然后自动构建和测试这些变更,以确保团队能够快速、高效地交付高质量的软件。

    个人理解:持续集成是一种软件开发方式,它要求一边开发一边频繁通过自动化脚本将变更集成到主分支中

  • 为什么需要持续集成

    持续集成可以提高软件的质量、快速定位发现问题、减少集成冲突和风险、提高软件开发效率。

    现代应用开发的目标是让多位开发人员同时处理同一应用的不同功能。但是,如果企业安排在一天内将所有分支源代码合并在一起(称为“合并日”),最终可能造成工作繁琐、耗时,而且需要手动完成。这是因为当一位独立工作的开发人员对应用进行更改时,有可能会与其他开发人员同时进行的更改发生冲突。如果每个开发人员都自定义自己的本地集成开发环境(IDE),而不是让团队就一个基于云的 IDE 达成一致,那么就会让问题更加雪上加霜。

    持续集成(CI)要求开发人员频繁地(有时甚至每天)将代码更改合并到共享分支或“主干”中。一旦开发人员对应用所做的更改被合并,系统就会通过自动构建应用并运行不同级别的自动化测试(通常是单元测试和集成测试)来验证这些更改,确保这些更改没有对应用造成破坏。这意味着测试内容涵盖了从类和函数到构成整个应用的不同模块。如果自动化测试发现新代码和现有代码之间存在冲突,可以更加轻松地快速修复这些错误。

持续交付

  • 什么是持续交付

    持续交付(Continuous Delivery,简称 CD)是一种软件开发实践,旨在通过自动化的构建、测试和部署流程,确保软件可以随时以可靠的方式交付给用户,但与持续部署不同,持续交付并不要求每次成功的构建都自动部署到生产环境中。

    个人理解:持续交付和持续集成一样,都是一种软件开发的方式,也可以理解为一种思想,他要求我们要有一个随时可以部署到生产环境的代码库

  • 为什么需要持续交付

    确保拥有一个可随时部署到生产环境的代码库,提高交付的效率。

  • 什么是持续部署

    持续部署(Continuous Deployment,简称 CD)是持续交付的一部分,指的是一种自动化的软件发布流程,其中每次成功的构建都会自动部署到生产环境中,从而使新功能或修复很快地被用户使用。

    个人理解:持续部署是持续交付的最后的一个步骤,他要求通过自动化脚本将已测试过的功能或修复发布到生产环境中,使得项目可以及时发现出隐藏的问题,从而得到快速的修复

持续部署

  • 什么需要持续部署

    提高部署效率、快速发现定位问题、降低应用的部署风险。

    持续部署,可以确保新功能能够很快上线被用户使用,用于越早使用,就能越快发现问题,从而越早改进,这样也能够帮助程序员快速定位问题,这一点的重要性我平常开发中深有体会,比如我开发一个比较大的功能,如果我是全部开发完后再来测试,可能看起来省时间,但是最终可能一旦出现问题,你需要定位很久,如果没开发一个小功能都测试一下,这样看着浪费时间,但是能够快速定位问题,反而能够更加节省时间,这也是一条开发的最佳实践。

Devops

  • 什么是DevOps

    DevOps(DevelopmentOperations,开发运维),是一种抽象的思想(类似与三层架构),它关注的是开发和运维之间的合作、沟通和整合。

    个人理解:从这个名字也可以看出来,他就是让开发与运维相结合,开发人员了解并参与运维,运维人员了解并参与开发,使得两者的沟通更加容易,开发人员可以开发出更好运维的应用,运维人员可以根据开发的应用制定更好的运维方案。现在市面上也有相应的 DevOps 开发工程师,薪资一般比单一的开发要高,毕竟会的多一点,学习成本更高

  • CI/CD 和 DevOps的联系

    DevOps 旨在打破开发和运维之间的壁垒,促进团队之间的协作和整合。它关注整个应用生命周期,包括需求分析、设计、开发、测试、部署和运维。DevOps 鼓励团队成员之间的沟通、协作和反馈,以便更好地满足客户需求,提高软件质量和交付速度。

    而 CI/CD 是一种实现 DevOps 理念的具体方法。通过持续集成、持续交付和持续部署,CI/CD 将开发、测试和部署过程自动化,以便更快速、更可靠地向客户交付软件。CI/CD 关注的是如何频繁地构建、测试和部署软件,以便及时发现和修复问题,同时提高软件质量和交付速度。

    因此,可以说 CI/CD 是 DevOps 的一种具体实践,它通过自动化方法来践行 DevOps 的核心理念,即开发和运维之间的紧密合作和协作。

CI/CD相关应用介绍

Jenkins

Jenkins是一个Java开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件项目可以进行持续集成。它前身是Hudson,2009年,甲骨文收购Sun并继承了Hudson代码库,2011年年初,甲骨文和开源社区关系破裂,该项目分为两个独立的项目:Hudson:由甲骨文继续管理; Jenkins:由大部分原始人员组成管理。

PS:是目前市场上最主流的 CI/CD 工具

Tekton Pipelines

Tekton Pipelines 基于Kubernetes并支持声明式构建。它使用自定义资源(Custom Resource)来定义构建任务,并使用Kubernetes API进行交互。

在Tekton Pipelines中,任务(Task)是核心概念,它表示一个可执行的工作单元。任务可以包含多个步骤(Step),每个步骤可以执行不同的操作,例如下载代码、运行测试、构建镜像等。任务还可以依赖其他任务,并可以通过输出(Output)和输入(Input)与其他任务进行交互。

除了任务之外,Tekton Pipelines还支持工作区(Workspace)的概念。工作区为任务提供了一个隔离的环境,可以用于存储任务所需的文件和资源。每个任务都可以使用不同类型的工作区,例如源代码工作区、构建工作区和测试工作区等。

Spinnaker

Spinnaker是一个开源的多云持续交付平台,旨在将产品快速且持续地部署到多种云平台上。它定位于将发布和各个云平台解耦,以将部署流程流水线化,从而降低平台迁移或多云平台部署应用的复杂度。

Spinnaker支持Google、AWS EC2、Microsoft Azure、Kubernetes和OpenStack等云平台,并且可以无缝集成其他持续集成(CI)流程,如git、Jenkins、Travis CI、Docker registry、cron调度器等。它具有以下主要功能:

  1. 集群管理:可以管理多云环境下的k8s集群。
  2. 部署管理:即常说的持续交付。

Spinnaker通过内置的部署策略(例如红色/黑色和金丝雀部署)利用云中的不变基础架构,创建和部署不可变映像以实现更快的部署、更容易的回滚以及消除难以调试的配置漂移问题。此外,Spinnaker还可以通过托管交付在上述功能的基础上提供更高级别的体验。

Travis CI

Travis CI是一个持续集成服务,它与Github紧密集成,可以在代码提交时自动运行测试和构建,并且可以将新代码集成到主干。它支持多种语言和框架,并且提供丰富的文档和社区支持。Travis CI还提供免费的公开仓库,可以用于托管开源项目。

GoCD

GoCD是一个开源的持续集成和持续部署工具,由ThoughtWorks开发并维护。它基于模型构建,采用了一种分阶段的模型来描述工作流。GoCD支持各种任务,如构建、测试和部署等,这些任务可以在不同的阶段中执行,并且可以并行或串行执行。

GoCD的核心概念包括:

  1. Pipeline:工作流是由一系列阶段(Stage)组成的Pipeline,每个阶段可以包含多个任务(Task)。
  2. Stage:阶段是一组任务的集合,这些任务按照顺序执行,通常用于表示一个完整的业务流程或功能。
  3. Task:任务是Pipeline中的基本执行单元,可以是一个命令行任务、shell脚本、Maven命令、NAnt脚本等。
  4. Agent:代理是用于执行任务的实际机器,GoCD可以与多个代理通信,并将任务分配给它们执行。
  5. Material:材料是用于触发Pipeline执行的文件或代码变更,通常与版本控制系统(如Git)集成。

GoCD还提供了可视化界面,可以方便地查看Pipeline的执行情况和日志,以及进行任务管理和配置。此外,GoCD还支持插件机制,可以扩展其功能和集成其他工具。

总之,GoCD是一个功能强大的持续集成和持续部署工具,适用于各种规模的项目和团队。它通过模型构建和可视化界面提供了灵活的工作流管理和任务执行能力。


参考资料

  • 一文带你看懂 CI/CD 是什么? (redhat.com)
  • Jenkins 构建CI/CD(一看就会)咸蛋黄派的博客-CSDN博客
  • DevOps到底是什么意思? - 知乎 (zhihu.com)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.kler.cn/a/136131.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Apache POI(Java)

一、Apache POI介绍 Apache POI是Apache组织提供的开源的工具包(jar包)。大多数中小规模的应用程序开发主要依赖于Apache POI(HSSF XSSF)。它支持Excel 库的所有基本功能; 文本的导入和导出是它的主要特点。 我们可以使用 POI 在…

1. hadoop环境准备

环境准备 准备三台虚拟机&#xff0c;配置最好是 2C 4G 以上 本文准备三台机器的内网ip分别为 172.17.0.10 172.17.0.11 172.17.0.12本机配置/etc/hosts cat >> /etc/hosts<<EOF 172.17.0.10 hadoop01 172.17.0.11 hadoop02 172.17.0.12 hadoop03 EOF本机设置与…

基于一致性算法的微电网分布式控制MATLAB仿真模型

微❤关注“电气仔推送”获得资料&#xff08;专享优惠&#xff09; 本模型主要是基于一致性理论的自适应虚拟阻抗、二次电压补偿以及二次频率补偿&#xff0c;实现功率均分&#xff0c;保证电压以及频率稳定性。 一致性算法 分布式一致性控制主要分为两类&#xff1a;协调同…

Java格式化类Format

文章目录 Format介绍Format方法- format&#xff08;格式化&#xff09;- parseObject&#xff08;解析&#xff09; 格式化分类日期时间格式化1. DateFormat常用方法getInstancegetDateInstancegetTimeInstancegetDateTimeInstance 方法入参styleLocale 2. SimpleDateFormat常…

电子学会C/C++编程等级考试2022年06月(一级)真题解析

C/C++等级考试(1~8级)全部真题・点这里 第1题:倒序输出 依次输入4个整数a、b、c、d,将他们倒序输出,即依次输出d、c、b、a这4个数。 时间限制:1000 内存限制:65536输入 一行4个整数a、b、c、d,以空格分隔。 0 < a,b,c,d < 108输出 一行4个整数d、c、b、a,整数之…

初识分布式键值对存储etcd

欢迎大家到我的博客浏览。胤凯 (oyto.github.io)大家好&#xff0c;今天我带大家来学习一下 etcd。 一、什么是 etcd etcd 是一个开源的分布式键值存储系统&#xff0c;主要用于构建分布式系统中那点服务发现、配置管理、分布式锁等场景。它采用 Raft 一致性算法来确保所有节…

Zotero在word中插入带超链接的参考文献/交叉引用/跳转参考文献

Zotero以其丰富的插件而闻名&#xff0c;使用起来十分的带劲&#xff0c;最重要的是它是免费的、不卡顿&#xff0c;不像某专业软件。 然而Zotero在word插入参考文献时&#xff0c;无法为参考文献添加超链接&#xff0c;这是一个不得不提的遗憾。 不过&#xff0c;有大佬已经…

工作记录---为什么双11当天不能申请退款?(有趣~)

为什么&#xff1f; 服务降级了 服务降级&#xff1a; 当服务器压力剧增的情况下&#xff0c;根据实际业务情况及流量&#xff0c;对一些服务和页面有策略的不处理或换种简单的方式处理&#xff0c;从而释放服务器资源以保证核心交易正常运作或高效运作。 分布式系统的降级…

万字长文 - Python 日志记录器logging 百科全书 - 高级配置之 日志分层

万字长文 - Python 日志记录器logging 百科全书 - 高级配置之 日志分层 前言 在 Python 的logging模块中&#xff0c;它不仅提供了基础的日志功能&#xff0c;还拥有一系列高级配置选项来满足复杂应用的日志管理需求。 说到logging 模块的高级配置&#xff0c;必须提及日志分…

LangChain 5易速鲜花内部问答系统

展示了一个完整的问答系统的实现&#xff0c;使用了Flask来构建Web界面、langchain进行文档处理和检索&#xff0c;以及OpenAI的语言模型。代码的复杂性在于集成了多种高级技术和处理大型数据集和语言模型。 LangChain 实现给动物取名字&#xff0c;LangChain 2模块化prompt t…

使用cli批量下载GitHub仓库中所有的release

文章目录 1\. 引言2\. 工具官网3\. 官方教程4\. 测试用的网址5\. 安装5.1. 使用winget安装5.2. 查看gh是否安装成功了 6\. 使用6.1. 进行GitHub授权6.1.1. 授权6.1.2. 授权成功6.2 查看指定仓库中的所有版本的release6.2.1. 默认的30个版本6.2.2. 自定义的100个版本6.3 下载特定…

暖阳脚本_ 将Agent技术的灵活性引入RPA,清华等发布自动化智能体ProAgent

RPA暖阳脚本 近日&#xff0c;来自清华大学的研究人员联合面壁智能、中国人民大学、MIT、CMU 等机构共同发布了新一代流程自动化范式 “智能体流程自动化” Agentic Process Automation&#xff08;APA&#xff09;&#xff0c;结合大模型智能体帮助人类进行工作流构建&#x…

2024年山东省职业院校技能大赛中职组 “网络安全”赛项竞赛试题-C卷

2024年山东省职业院校技能大赛中职组 “网络安全”赛项竞赛试题-C卷 2024年山东省职业院校技能大赛中职组 “网络安全”赛项竞赛试题-C卷A模块基础设施设置/安全加固&#xff08;200分&#xff09;A-1&#xff1a;登录安全加固&#xff08;Windows, Linux&#xff09;A-2&#…

【grafana | clickhouse】实现展示多折线图

说明&#xff1a; 采用的是 Visualizations 的 Time series&#xff0c;使用的 clickhouse 数据源 在工作中遇到了一个需求&#xff0c;写好了代码&#xff0c;需要在grafana上展示在一个项目中所有人的&#xff0c;随时间的代码提交量变化图 目前遇到的问题&#xff1a;展示…

十一、统一网关GateWay(搭建网关、过滤器、跨越解决)

目录 一、网关技术的实现 在SpringCloud中网关的实现包括两种: 作用&#xff1a; 二、搭建网关服务 1、新建模块&#xff0c;并添加依赖 2、新建Gateway包&#xff0c;并编写启动类 3、编写yml文件 4、启动服务&#xff0c;并在网页内测试 5、步骤 三、路由断言工厂 …

【手撕数据结构】(三)顺序表和链表

文章目录 一、线性表二、顺序表1.概念及结构2.关于数组3.顺序表分类&#x1f397;️静态顺序表&#x1f397;️动态顺序表 4.接口实现&#xff08;1&#xff09;思路&#xff08;2&#xff09;SeqList.h文件代码功能1&#xff1a;顺序表初始化功能2&#xff1a;销毁顺序表功能3…

PyCharm:PyCharm新建.py文件时自动带出指定内容

在pycharm中加上指定内容&#xff0c;每次新建.py文件都会自动带出指定内容 操作&#xff1a; File—Setting—Editor----File and Code Templates--Python Script 在右侧窗口中加上如下信息 # encoding: utf-8 # author: Jeffrey # file: ${NAME}.py # time: ${DATE} ${TI…

服务器端请求伪造(SSRF)

概念 SSRF(Server-Side Request Forgery&#xff0c;服务器端请求伪造) 是一种由攻击者构造形成的由服务端发起请求的一个安全漏洞。一般情况下&#xff0c;SSRF是要攻击目标网站的内部系统。&#xff08;因为内部系统无法从外网访问&#xff0c;所以要把目标网站当做中间人来…

[github配置] 远程访问仓库以及问题解决

作者&#xff1a;20岁爱吃必胜客&#xff08;坤制作人&#xff09;&#xff0c;近十年开发经验, 跨域学习者&#xff0c;目前于新西兰奥克兰大学攻读IT硕士学位。荣誉&#xff1a;阿里云博客专家认证、腾讯开发者社区优质创作者&#xff0c;在CTF省赛校赛多次取得好成绩。跨领域…

数据结构02附录01:顺序表考研习题[C++]

图源&#xff1a;文心一言 考研笔记整理~&#x1f95d;&#x1f95d; 之前的博文链接在此&#xff1a;数据结构02&#xff1a;线性表[顺序表链表]_线性链表-CSDN博客~&#x1f95d;&#x1f95d; 本篇作为线性表的代码补充&#xff0c;每道题提供了优解和暴力解算法&#xf…
最新文章