前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >CICD流程建设之持续集成实践指南

CICD流程建设之持续集成实践指南

原创
作者头像
嘉为蓝鲸
发布2024-12-12 10:54:10
发布2024-12-12 10:54:10
2100
举报
文章被收录于专栏:DevOpsDevOps

随着软件开发的快速迭代和交付周期的日益缩短,持续集成与持续部署(CICD)逐渐成为了软件开发流程中不可或缺的一环。

CI属于开发人员的自动化流程,主要用于构建软件并完成初始测试。它确保代码在集成到共享仓库之前,通过自动化的方式进行检查和验证,以便尽早发现并解决问题。

CD则分为持续交付和持续部署两部分。持续交付是指开发人员对应用的更改会自动进行持续测试并上传到制品库,然后由运维团队将其部署到实时生产环境中。持续部署则是自动将开发人员的更改从制品库发布到生产环境,以供客户使用。

01

什么是CICD流水线?


CI/CD通常表示为一个管道,其中新代码从一端进入,流经一系列阶段(生成、测试、暂存、生产),并作为新的生产版本发布给另一端的最终用户。

CI/CD流水线的每个阶段都是交付过程中的一个逻辑单元。开发人员通常将每个单元划分为一系列按顺序或并行运行的子单元CI/CD流水线是所有软件在其开发生命周期中遵循的可运行的分步路径。

典型的CI/CD流水线有四个主要阶段:提交、构建、测试和部署。

图片
图片

CI/CD流水线不会改变开发人员创建软件的方式。在没有自动化管道的情况下,工程师仍然需要手动执行相同的步骤。但是,手动方法的工作效率较低,因为团队必须更多地关注重复性任务和修复错误,而不是编写软件。

自动化流水线为团队提供了几个好处:

快速部署新的软件更新

可靠的构建和测试流程

减少生产中出现的错误和错误

所有代码更改、测试和部署的透明日志

图片
图片

上图描述了一个完整的CI流程:

开发人员将代码签入其工作站进行编辑。

开发人员将修改提交到存储库。

在接受提交之前,会检查代码的质量和语法。

Commit 启动应用程序的生成。

如果无法构建应用程序,则会通知团队解决问题。

生成服务器对应用程序执行单元测试。

如果应用程序通过测试用例,则会通知团队可以合并代码。

如果程序未通过测试用例,则代码将返回给开发团队以修复错误。

在整个开发阶段应重复此循环。

实践CI的优点

CI帮助团队在不影响质量的情况下可以加快他们的软件发布周期。持续集成的主要目标是缓解部署过程中可能出现的潜在风险,并缩短反馈循环。

图片
图片

02

企业级流水线实践指南


尽管不同企业有不同的研发管理规范,每家公司都会根据其独特的需求定义其CI实践。但高效的CI流水线都必须有如下的规范:

1流水线的关键要素

通过采用明确的CI定义并在其开发过程中实施该实践,团队可以简化他们的工作流程并提高他们的软件质量。定义持续集成的关键要素如下:

图片
图片

2流水线命名规范

创建工程流水线时,需要统一命名规范,主要分为两种类型,即正式和非正式,具体如下:

非正式的流水线,[DEV]_个人标识_模块名,如:[DEV]_xxx_payment;

正式的流水线,[RELEASE]_微服务名_<前端/后端/移动端>,如[RELEASE]_保单业务_后端;

3流水线编排规则

图片
图片

CI实践是用于自动化和缩短反馈时间的流行软件开发实践。但是,如果设置不当,CI管道反而会降低代码质量并导致开发延迟。因此,遵循CI/CD最佳实践进行软件开发非常重要。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 01
  • 什么是CICD流水线?
  • 02
  • 企业级流水线实践指南
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档