写点什么

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

2020 年 4 月 18 日

如何以可组合块的方式重构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 年 4 月 18 日 09:001320

评论

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

【TcaplusDB小知识】TcaplusDB的技术原理

数据人er

数据库 nosql TcaplusDB 国产数据库

网络协议学习笔记 Day5

穿过生命散发芬芳

网络协议 4月日更

基于MySQL存储的自研消息队列架构设计文档

Geek_2e7dd7

面向软件 IT 专业的高校大学生职业规划问卷调查

打工人!

IT 问卷调查 职业生涯规划

chia奇亚分币软件开发|chia奇亚分币APP系统开发

开發I852946OIIO

系统开发

IT 专业的高校大学生编程技能及就业问卷调研

Yano

问卷调查

容器 & 服务: 扩容(二)

程序员架构进阶

容器 k8s 28天写作 弹性扩容 4月日更

热烈祝贺中国广告协会户外广告分会第五届二次常委会顺利召开

󠀛Ferry

四月日更

聪明人的训练(二十六)

Changing Lin

4月日更

阿里P8独家揭秘:短期内升职加薪的方法,到底是什么?

Java架构师迁哥

看完清华学霸整理的完整版Java反射机制题目,再进大厂面试就稳了

java专业爱好者

Java

2021团体程序设计天梯赛-部分题解

玄兴梦影

算法 比赛 算法解析

2021金三银四最新拼多多 +蚂蚁金服 +头条(已拿offer),面试真题分享!

云流

Java 编程 程序员 架构 面试

近期值得关注的四款工具

彭宏豪95

效率 工具 Mac 4月日更

JVM类加载机制笔记

风翱

4月日更 JVM类加载

贝壳基于 Flink 的实时计算演进之路

Apache Flink

flink

xch挖矿APP开发|xch挖矿系统软件开发

开發I852946OIIO

系统开发

Gartner加速数字化电子书系列(下):完善CIO角色,引领数字化加速

Geek_bacee5

Gartner Gartner加速数字化电子书

教育是限制吗?

箭上有毒

4月日更

学了2年Java,在北京根本收不到offer,面试官:IO流操作都不会

java专业爱好者

Java

【死磕JVM】什么是JVM调优?

牧小农

JVM jvm调优 JVM基础

腾讯云TcaplusDB数据库服务《上古卷轴:刀锋》 助力手游行业发展

数据人er

数据库 nosql TcaplusDB Tcaplus 国产数据库

MySQL 死锁套路:一次诡异的批量插入死锁问题分析

AI乔治

Java MySQL 架构

基于区块链技术的去中心化自治组织——核心属性、演进脉络与应用前景

CECBC区块链专委会

区块链

聚力边缘计算 共建数字中国丨浪潮边缘云ICP Edge 2.0 全新发布

浪潮云

腾讯云TcaplusDB数据库联合盛趣游戏打造《上古卷轴:刀锋》传奇

TcaplusDB

数据库 nosql 技术 后端

Linux字符截取命令-cut

进击的梦清

Linux 运维 xshell

RocketMQ 在使用上的一些排坑和优化

AI乔治

Java 架构 分布式 RocketMQ 高并发

Gartner加速数字化电子书系列(下):IT部门数字化业务转型路线图

Geek_bacee5

Gartner 数字化业务转型IT路线图

怎么理解组织?

石云升

团队建设 28天写作 职场经验 管理经验 4月日更

金三银四 Java 架构面试指南上线, 1000 余道大厂面试真题,送你上岸

云流

Java 编程 程序员 架构 面试

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