两大阐释、四大流程,拿下CI/CD

2020 年 4 月 12 日

两大阐释、四大流程,拿下CI/CD

在最好的时候创建用户喜欢的高质量应用程序并不是件容易的事情。更何况,要怎样做才能更快地创建用户喜欢的高质量应用程序并且能够不断改进它们呢?这就是需要引入持续集成和持续交付(CI / CD)的地方。


持续集成(CI)


什么是持续集成?


那么,持续集成(CI)究竟是什么呢?它是软件工程师每天频繁地将更新代码的副本传递到共享位置的过程。所有的开发工作都在预定的时间或事件中进行集成,然后自动测试和构建工作。通过 CI,开发过程中出现的错误能被及时发现,这样不仅加速了整个开发周期,而且使软件工程师的工作效率更高。


持续集成有什么好处?


我们不能低估 CI 的好处。因为团队里的人都在同一个产品上进行实时工作,所以在软件开发过程中使用 CI 时,你可以期望实现更快的速度、更好的稳定性和更强的可靠性。并且在开发过程的早期,开发人员能够发现和解决任何编码问题,使它们在成为下游主要问题之前得到纠正。这样可以降低错误代码导致的长期开发(和业务)的成本。


持续集成对于 QA 测试花费的时间也有很大的影响。通过 CI,开发人员不断审查和编辑以前的代码,能够检查到许多小的错误,这些错误在 QA 里通常发现的晚一些。这使得测试人员不仅可以专注研究代码和关注更加紧迫的问题,而且能够同时测试更多的场景。


对开发团队来说,使用 CI 的另一个好处是可以提高编码能力。由于持续发展的自然灵活性,这使得开发人员能够快速、轻松地对代码进行更改,却不会产生运行回归风险。


持续交付(CD)


什么是持续交付?


持续交付(CD)是创建高质量应用程序的第二个难题。CD 是一门软件开发学科,利用技术和工具快速地交付生产阶段的代码。由于大部分交付周期都是自动化的,所以这些交付能够快速地完成。


持续交付有什么好处?


实施持续交付的主要好处是能够加快应用程序的上市时间。使用 CD 的公司能大大增加他们的应用程序发行频率。在没有使用 CD 之前,应用程序发布的频率通常是几个月一次。然而现在使用 CD,你可以一个星期发布一次、甚至每天发布多次应用。在竞争激烈的行业中,速度的提高将会使你处于主要优势。


持续不断的软件版本发布也会根据用户对应用程序的反馈,允许开发团队对其进行微调。这个用户反馈为开发人员提供了所需要的洞察力,并且它优先考虑了用户实际需要的功能请求。同样重要的是,对用户实际上没有用到的应用程序功能,它允许开发人员对其进行优先级排序。


CD 的另一个好处是它能保证每个发行版本的风险较低。当使用 CD 方法发布时,开发团队也会更有信心,因为在整个开发生命周期中,所有内容都经过了多次测试。


任何不考虑转向 CI / CD 的公司都或将被那些使用 CI / CD 方法的竞争对手远远地甩在后面。那么,如何转向 CI / CD?当您准备转向持续集成/持续交付(CI / CD)时,需要考量及决定的相关流程有很多。下文将带您了解这些主要流程。


转向 CI/CD 的重要流程


1 分支和合并


你需要组织及考虑的一个主要流程就是你的分支和合并。分支就是开发人员可以在代码的平行部分工作的地方——从一个中央代码库分支出来。分支的好处在于,它允许在不破坏中心代码基础的情况下,在软件构建的不同方面同时进行工作。显然,合并即意味着分支合并到核心代码库。


通过各种版本控制系统,许多开发人员对分支和合并已经很熟悉了。然而,根据您的构建的特别要求,您所分支的内容也有很多不同的策略。有些开发人员将通过维护、功能或团队来进行发布的分支。


您可能会对某种策略非常狂热,但“绝对正确”的分支和合并策略是不存在的,只存在“对您的构建而言正确”的方式与策略。这需要检查您当前的分支和合并策略,并根据您的目标和情况决定需要更改哪些内容。


2 构建自动化


构建自动化意味着您可以自动编译软件构建。持续集成服务器的核心是构建自动化服务器,其工作是在触发或定时的基础上编译和链接源代码。您选择的持续集成服务器将成为您的 CI/CD 环境的支柱。


在查看构建自动化过程时,了解市场上各种可用选项的功能是非常有帮助的。开源公司 Jenkins 现在在 CI/CD 部署中占绝对优势,这通常是一个好的开始。或者至少,在比较其他解决方案时把它作为基准。作为一个开源代码系统,您可能仍需构建一些实用程序,以使构建自动化完全适合您的情况。


3 测试自动化


测试自动化对于 CI/CD 能否按预期工作至关重要。如果没有自动化测试,CI/CD 将很快无法实现快速交付的目标。我们的总体建议是尽可能自动化。这意味着您需要检查您需要执行的各种测试,并决定在您的环境中可以安全地自动进行哪些测试。


建立测试自动化环境可能需要新的技能。然而,这是战略需求,将会提高交付速度,减少错误。至少,您应该自动化代码审查、单元测试、集成测试和系统测试。


4 部署自动化


关于持续交付和持续部署之间的区别,仍然存在一些混淆。简而言之,持续交付意味着持续推出发布就绪代码,而持续部署则意味着持续给用户部署该软件。


无论你在看什么“CD”,对那些不习惯的人来说,这似乎是一个巨大的飞跃。为了让您的组织有信心将软件部署到最终用户,需要一个严密的测试自动化基础设施。


我们的建议是,最好进入流程定义,以实现零接触持续部署的总体目标。虽然领先的持续集成系统通常会考虑自己的持续交付系统,但您可以比现成的参数更进一步。真正的敏捷性需要构建一个基础设施、写好代码,吸引用户使用。


选择开源且完整的 CI/CD 的工具


真正实现 CI/CD 并非易事,pipeline 搭建工作复杂,平滑升级难以保障,服务宕机难以避免……选择一个完整的 CI/CD 工具,将大大助力于 CI/CD 在企业里落地并最终带来生产运维效率的提升。Rancher Labs 新近发布的 CI/CD 工具 Rancher Pipeline,就拥有极简的操作体验,强大的功能整合,并且完全开源。


  • 同时支持多源码管理:在单一环境中同时拉取、使用和管理托管在GitHub和GitLab的代码;

  • 一键部署,完全可视化的pipeline配置,拖拽方式的pipeline搭建;

  • 阶段式和阶梯式pipeline,可自由扩展的步骤系统;

  • 灵活的流程控制:不同的代码分支可以自动匹配不同的CI流程,从而支持较为复杂的流程控制

  • 支持多种触发方式:计划任务的触发、来自GitHub / GitLab的webhook触发、手动触发,以及通过定制化的开发,实现更多种触发方式的支持

  • 良好集成的审批系统:审批系统已与Rancher用户管理系统集成,且用户可以在任意阶段插入断点,自由地对任意阶段进行审批

  • 灵活的pipeline启停机制:任一环节出错,整个进度可以立即停止,而问题解决之后又可以重新运行


英文原文:


https://www.infostretch.com/blog/the-promise-of-continuous-integration-and-continuous-delivery/


https://www.infostretch.com/blog/the-processes-to-nail-in-your-move-to-cicd/


2020 年 4 月 12 日 20:39166

评论

发布
暂无评论
发现更多内容

好玩又好用,一款轻松就可以实现音视频的Demo

anyRTC开发者

音视频 移动互联网 RTC anyRTC Demo

DSN主流项目调研1——Storj和Arweave的简介

AIbot

分布式存储 区块链+ 分布式文件存储 Storj Arweave

区块链技术在银行业的运用

CECBC区块链专委会

区块链 信息安全 金融

写给想学和在学编程的你们,学习编程的7个好处

三钻

学习 软件开发 编程之路 程序员成长 经验分享

docker-compose构建springcloud微服务项目

xcbeyond

Java Docker Docker-compose springboot

【第十周】学习笔记

Aldaron

VSCode插件大全|VSCode高级玩家之第二篇

三钻

程序员人生 vscode 编辑器 插件 技巧

一文道尽“表驱动法”

flyer0126

编码 表驱动法

国家央行数字货币的优势与挑战

CECBC区块链专委会

数字货币 央行 商业银行

IDEA直连服务器,进行项目Docker部署,实现一键部署、启动

xcbeyond

Java Docker idea插件

你还应该知道的哈希冲突解决策略

vivo互联网技术

哈希冲突

华章25周年活动——《迁移学习》限量5折!

华章IT

LeaRun快速开发平台,快速开发.net/java项目

力软.net/java开发平台

DSN 主流项目调研 0——IPFS&&Filecoin白皮书总结

AIbot

区块链 分布式存储 分布式文件存储 IPFS Filecoin

CentOS7 下Docker安装、启动

xcbeyond

Docker 软件安装

图解JavaScript——代码实现(六种异步方案,重点是Promise、Async、发布/订阅原理实现,真香)

执鸢者

原理 异步 Promise Async

【第十周作业】

Aldaron

更优雅的编写JavaScript

三钻

Java 前端 程序员素养 经验分享 ES6

用“易于改编”原则,提升编程水平,写出更好的代码

三钻

前端 后端 程序员成长 经验分享 编程风格

Git分支管理策略及简单操作

王坤祥

git git flow

Kafka实战宝典:一文带解决Kafka常见故障处理

数据社

kafka 监控

分布式定时任务调度框架实践

vivo互联网技术

分布式 大数据任务调度 框架

5大法则助你 成为更出色的开发者

三钻

学习 编程 敏捷开发 程序员成长 经验分享

优质单元测试的十大标准,你有遵循吗?

项目管理 单元测试 自动化测试

聊聊微前端的原理和实践

vivo互联网技术

前端 微前端

前端必看的8个HTML+CSS技巧

三钻

Java html html5 css3 前端

Kafka实战宝典:如何跨机房传输数据

数据社

大数据 kafka 跨机房

6个高效学习编程的方法

三钻

学习 程序人生 前端 后端

带你体验Vue2和Vue3开发组件有什么区别

三钻

Java Vue 前端 Vue3 React

你真的懂怎么写`服务层`吗?

三钻

php 后端 服务 程序员成长 架构思维

VSCode常用快捷键大全|VSCode高级玩家宝典之第一篇

三钻

学习 效率工具 程序员人生 vscode 快捷键

两大阐释、四大流程,拿下CI/CD-InfoQ