如何选择基于云的CI/CD平台?

如何选择基于云的CI/CD平台?

作者:黄豪杰 翻译 2021-07-27 08:01:22

云计算 在云中托管CI/CD既可以加快开发管道和源代码存储库之间的交互,也可以使开发人员的工作更轻松。

[[413408]]

本文转载自微信公众号「新钛云服」,作者黄豪杰 翻译  。转载本文请联系新钛云服公众号。

在云中托管CI/CD既可以加快开发管道和源代码存储库之间的交互,也可以使开发人员的工作更轻松。

如果你的目标是高速软件开发和将工作构建频繁交付到生产环境,则你需要至少自动化部分测试和交付过程。

理想情况下,这意味着为你的项目实施 CI/CD 管道,以及在客户看到软件之前捕获错误的测试套件,以及实现管道步骤的脚本。

持续集成 (CI) 是一种以一致的方式自动化软件构建、打包和测试的方法。CI 有助于让团队相信他们检查到源代码版本控制中的更改不会破坏构建或将错误引入软件。

CI 的端点通常是对软件存储库主分支的完整签入。

持续交付 (CD) 自动将经过测试的软件交付到基础设施环境。这通常并不意味着将其直接投入生产以查看客户是否抱怨。

通常,组织首先将构建推送到开发环境。在开发人员自己击败并发布新版本后,它通常会进入一个测试环境,在那里它被更广泛的用户群体使用(有时只是专门的内部测试人员,有时更多的用户注册了 beta 测试或“狗食”)并密切监控。

最后,如果一切顺利,测试人员会签字并将新版本推送到生产环境。

在 CD 的每个阶段,都有选项可以快速恢复到旧版本并生成错误报告票供开发人员在新版本中解决。目标不是将大量构建投入生产,而是在不引入回归的情况下不断改进和增强软件。这些实践的另一个术语是“devops”。

为什么要在云中托管 CI/CD?

在你自己的数据中心托管 CI/CD 平台是一个可行的选择,特别是对于要求在防火墙内托管其应用程序和数据的公司。这样做的缺点是你需要一个专门的团队来维护基础设施,并且你将承担一些服务器资本支出。

如果允许你在云中托管,通常是更好的选择。在云中托管的成本适中,运营费用由提供的服务抵消:入职、基础设施维护、安全维护、支持和 CI/CD 软件维护。在云中托管 CI/CD 软件通常会使管道与源代码存储库交互更容易、更快,如果它们也在云中。

如果你的开发人员和测试人员分布在不同的地理位置,与在防火墙后面的远程服务器中托管相比,在云中托管你的存储库通常会给开发人员带来更好的体验。

还可以在本地和云服务器的混合上部署 CI/CD。一些最新的 CI/CD 产品在 Kubernetes 集群上的容器中运行,这些集群在本地和云中运行同样愉快。在混合部署方案中,你可以将每个组件放置在考虑到开发人员本身的物理位置以及开发基础结构中其他服务器的网络位置最有意义的位置。

CI/CD 必须与你的存储库集成

正如你在阅读“CI 的端点通常是对软件存储库的主分支的完整签入”时可能已经收集到的那样,存储库对于 CI 和 CD 至关重要。

除了作为签入和测试过程的终点之外,软件存储库还是存储 CI 和 CD 脚本和配置文件的首选位置。是的,许多 CI/CD 平台可以在内部存储脚本和其他文件,但通常最好将它们置于工具之外的版本控制中。

几乎所有 CI/CD 工具都可以与 Git 交互。有些还直接与 GitHub、GitHub Enterprise、GitLab 和/或 Bitbucket 集成。一些还支持 Subversion 和/或 Mercurial。

你的 CI/CD 工具需要支持你的编程语言和工具

每个编程语言或语言组(JVM 语言、LLVM 编译语言、.NET 语言等)往往都有自己的构建工具和测试工具。为了对你有用,CI/CD 工具必须支持作为给定项目一部分的所有语言。否则,你可能需要为该工具编写一个或多个插件。

Docker 镜像对于分布式、模块化和微服务软件部署变得越来越重要。如果你的 CI/CD 工具知道如何处理 Docker 镜像,包括从源代码、二进制文件和先决条件创建镜像,以及将镜像部署到特定环境,那么这将大有帮助。

同样,如果没有这个,你可能需要编写插件或脚本来实现你需要的 Docker 功能。同样,你希望 CI/CD 工具支持 Kubernetes 和你在环境中使用的任何其他容器编排系统。

你的开发人员是否了解 CI/CD 和你正在考虑的工具?

CI 和 CD 的原理看似显而易见,但细节却并非如此。各种 CI/CD 工具具有不同级别的支持和文档。有很多关于 Jenkins 的书,这并不奇怪,因为它是最古老的书。

对于其他产品,你可能需要调查文档和支持论坛以及付费支持选项,作为你在选择工具时尽职调查的一部分。

关于CI的一般背景,请考虑Addison-Wesley的书《持续集成》(Continuous Integration),作者是Duvall等人。同样,对于CD的一般背景,可以参考Humble和Farley的Continuous Delivery。两本书出版时都获得了Jolt奖。

你可以为不同的项目选择不同的 CI/CD 工具

虽然本指南是关于选择 CI/CD 平台的,但请不要假设一个平台对于你的所有软件开发项目都是最佳的。大多数商店使用多种编程语言和环境,并不是每个 CI/CD 平台都能很好地支持所有这些。

随意选择最适合你的每个项目的 CI/CD 平台,而不是寻找一个折衷的平台。CI 和 CD 的一般原则从一个平台转移到另一个平台,即使你为它们编写的脚本可能并不总是可移植的。

虽然每个新平台的额外入门时间可能会让你的 DevOps 团队花费一些时间,但这很可能比需要广泛定制 CI/CD 工具更便宜。

规划未来的 CI/CD 迁移

同样,请不要假设给定的 CI/CD 平台将永远满足你的项目需求。始终对冲你的赌注,例如通过将脚本存储在存储库中而不是在 CI/CD 工具中。

在适当的情况下首选无服务器serverless CI/CD

一般来说,云容器部署比云服务器实例部署便宜,无服务器云部署比容器部署便宜。 不幸的是,在撰写本文时,很少有 CI/CD 平台可以无服务器运行。

无服务器意味着运行感兴趣的进程的容器在必要时被实例化,通常是为了响应一个事件。 对于 CI/CD,触发事件一般是代码签入到特定的存储库分支;然后存储库 Webhook 启动无服务器进程。当该过程完成时,资源被释放。

少数可以运行无服务器的 CI/CD 平台之一是无服务器 CI/CD,它是无服务器框架 Pro 的一部分,是开源无服务器框架的增强版本。无服务器 CI/CD 针对部署无服务器应用程序进行了优化,目前仅在 AWS 上运行。你必须确定它是否足够支持你的应用程序以供使用。

在提交之前做一个概念证明

一旦完全实施 CI/CD,它就会成为基础设施的重要组成部分。在你加快速度时请记住这一点。

在开始推出 CI/CD 管道之前执行严格的概念验证非常重要。在开始 CD 阶段之前,先将 CI 部分放下。在将任何 CI/CD 管道连接到生产实例之前,请确保练习测试套件和回滚功能,并让人工参与其中,直到你非常确定自动化坚如磐石。

 

原文链接:https://www.infoworld.com/article/3620932/how-to-choose-a-cloud-based-cicd-platform.html

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/283103.html<

(0)
运维的头像运维
上一篇2025-05-13 18:50
下一篇 2025-05-13 18:52

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注