【ArchSummit架构师峰会】探讨数据与人工智能相互驱动的关系>>> 了解详情
写点什么

如何以可组合块的方式重构 CI/CD 管道

  • 2020-04-18
  • 本文字数:1065 字

    阅读完需:约 3 分钟

如何以可组合块的方式重构CI/CD管道

DeliveryConf大会上,VMware 主管工程师Bryan Liles讨论了构建持续集成交付(CI/CD)管道的一系列原则。Liles 建议,应将 CI/CD 视为模式而非 Jenkins 或 Spinnaker 这样的具体实现;需要构建一种平台,它由独立于技术堆栈的可组合部分和可替换组件构成。


演讲一开始,Liles 介绍了会有多少企业按照传统的方式构建 CI/CD 管道,并阐明建立此类管道的目的是实现应用从开发环境到生产环境的迁移。交付过程在本质上就是从源代码管理方获取应用的代码,进而在管道中编译应用,形成工件并打包(bundle)存储在仓库中。最后,管道将打包文件交付给各个环境,例如开发、测试和生产。Liles 指出,如果交付管道看上去非常复杂,那么这意味着技术栈不应该再继续复杂下去了。


在 Liles 看来,工程人员应该将部署管道看成是一些可组合的块和模式,而非仅注重实际使用的 Jenkins 或 Spinnaker 等具体实现。例如,管道中的一部分可以是完成应用构建、运行测试和创建工件的集成块,该部分可以使用 Jenkins 实现,但也支持使用 Circle CI 等其他工具。管道中的另一个块可以部署应用、征求批准和执行数据迁移的交付过程。集成和交付块都具有一些相同的基本组件,例如 Webhook 触发器、工作流、通知和批准等。集成块和交付块是部署管道这一更大的可组合部分中的一部分。



Liles 提出:“必须更多地考虑系统的可组合性。”部署管道应该是一种将应用交付至指定目的地的应用发布“平台即服务”(PaaS)。Liles 建议将部署管道重新定义为可组合的 PaaS,工程人员可轻易更改其中的各个组件。该模式的典型例子就是 Kubernetes。作为构建平台的平台,部署管道可基于 Kubernetes 实现与上述集成块和交付块一样的基本组件,同时支持使用其它各种不同的工具。例如,集成部分可以使用TektonArgo实现触发器、工作流、通知和批准块。


Liles 进而指出,Jenkins、Spinnaker 或 ConcourseCI 之类的工具可用于定义如何构建 CI/CD 管道以及如何使用它们,但应在使用中汲取前车之鉴,避免入坑。由此,他建议应以破旧立新的思维去利用工具:


我们确实需要换种思维去使用各种工具。技术现状驱动我们到达了当前的位置,但这并非我们所需要的高度。我们应该拓展思维,破旧立新。


Liles 最后总结道,工具本身是复杂的,但从生态系统角度看,我们应致力于去构建更小且可组合的工具集。他建议工程人员琢磨一下如何共同改进生态系统,而不是沉溺于如何在现有工具上锦上添花。他认为自己提出的构建方式仅是抛砖引玉,“关注点应是更多地考虑系统中的可组合性。”


原文链接:


Reimagining CI/CD Pipelines as Composable Blocks with Bryan Liles


2020-04-18 09:001717

评论

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

Apache下error.log文件太大的处理方法

一直AC一直爽

WebRTC框架下的实时视频关键路径

fumingwang

面试官拿System.out.println()考了我半个小时?我傻了

Java小咖秀

面试

爸爸,我想握住你的手

一直AC一直爽

随笔杂谈 父爱

广义表的实现!

烫烫烫个喵啊

算法 广义表

【一起学系列】之命令模式:封装一个简单Jedis

Kerwin

设计模式 命令模式 Jedis

企业架构框架之FEA

冯文辉

企业架构

性能测试和并发压力的关系

王锟

性能测试与优化 和 操作系统与文件系统

满山李子

极客大学架构师训练营

寻找感动的养分

一直AC一直爽

感恩 随笔杂谈 感动

HashiCorp官宣:禁止国内使用其旗下Consul等开源软件?

xcbeyond

Consul 条款

架构师第七周作业

傻傻的帅

第七周学习总结

王锟

读《我的大学,我的苦难》有感

一直AC一直爽

随笔杂谈 读后感

技术面试官应该怎么问?面试者应该怎么答?

xcbeyond

面试 自我介绍

MinIO 参数解析与限制

耳东@Erdong

配置 Minio

手写实现Promise

GKNick

剪刀爱情

一直AC一直爽

电影

ZK 从入门到放弃 入门篇

小隐乐乐

我向面试官讲解了单例模式,他对我竖起了大拇指

cxuan

设计模式 单例模式

如何写出完美的接口:接口规范定义、接口管理工具推荐

xcbeyond

接口规范 接口管理工具 swagger Easy Mock

英特尔唐炯:把最好、最合适的产品带给最需要的消费者

最新动态

Mysql错误:Ignoring query to other database解决方法

一直AC一直爽

MySQL

手把手教你写数独计算器(1)

一直AC一直爽

c++ 算法 数独

ARTS-WEEK7

一周思进

ARTS 打卡计划

我有一个梦想

一直AC一直爽

随笔杂谈 梦想

47 张图带你 MySQL 进阶!!!

cxuan

MySQL 后端

JVM系列之:String,数组和集合类的内存占用大小

程序那些事

Java JVM GC JOL

总结:PHP值得注意的几个问题

一直AC一直爽

php

MinIO 分布式集群搭建

耳东@Erdong

Minio cluster Minio 集群

直播中那几秒延时到底来自哪?

阿里云Edge Plus

CDN 云直播 直播 直播带货

如何以可组合块的方式重构CI/CD管道_软件工程_Christian Melendez_InfoQ精选文章