DevOps落地实践:BAT系列:CICD:iPipe vs CCI

DevOps落地实践:BAT系列:CICD:iPipe vs CCI_第1张图片
百度效率云,将自身定位为研发工具的SaaS解决方面,三大看点代码托管/CICD/敏捷看板非常清晰,对应icode/ipipe/icafe三大自研工具。而腾讯的DevOps解决方案聚焦于代码托管/CICD/测试管理/运维监控/项目管理五大领域,具体则依托于腾云TGit/CCI/COC/TAPD四大开发者工具。因为功能和做法较为相近,这篇文章中我们将会通过其官方的介绍来看一下CICD的具体做法和各自的亮点。

CCI持续集成

为开发者提供支持多种编程语言的编译构建服务,包含定时/手动启动构建、查看构建结果及日志、支持快速分发交付、可扩展的自动化测试等功能,为项目的持续集成体系提供上游基础服务,提升项目研发效率。
DevOps落地实践:BAT系列:CICD:iPipe vs CCI_第2张图片

Why CCI

优势 详细说明
接入门槛低 通过认证的腾讯云帐号,CCI 可直接同步 TGit 的代码库进行构建任务的创建;并提供了多台标准编译机,基础构建任务无需进行编译机购买及环境搭建工作。
配置灵活 CCI 提供丰富的自定义编译参数,满足各种复杂编译任务需求;支持接入私有编译机,满足用户特殊编译环境的任务需求;支持接入第三方代码源,可从 Github 或其他 SVN 代码源拉取代码完成构建。
流水线对接 在同步 TGit 代码的同时,CCI也能获取到 TGit 的提交日志,关联变更与构建结果;可自动或手工将构建结果同步至织云文件管理模块,对构建结果进行版本管理,进而完成批量机器自动化部署工作。
可扩展性强 可配置定时触发构建或代码提交触发构建,快速迭代更新;构建下游提供开放接口,可接入各类自动化检测工具(如代码静态扫描、安装包检测),快速诊断代码问题,提升测试质量。

产品功能

功能 详细说明
构建任务管理 灵活的构建任务配置,可针对不同项目配置一到多个构建任务,独立产出构建结果。
编译参数场景 系统支持默认构建参数,允许自定义配置构建参数及构建脚本,满足个性化构建需求。
编译机管理 提供了多台标准编译机,支持接入私有编译机,支持用户特殊编译环境的任务。
自动触发机制 用户可手动触发构建以外,可定时或代码提交时触发构建,满足每日基线及实时基线结果诉求。
关联提交行为 CI可拉取tGit或其他代码源的提交日志,为每次构建结果关联上代码提交日志,方便跟踪代码提交产出。
无需人工介入 通过后台的构建集群,CI可保证编译的安全及稳定;构建完成后通过各类通知方式进行结果同步,无需值守或干预。
代码托管 通过认证的腾讯云帐号,CCI 可直接拉取同一个开发者(或企业)的 TGit 项目,降低项目接入开销。
发布部署 CCI 结果可一键或自动将构建结果同步至织云文件管理模块,对构建结果进行版本管理,协助完成批量机器自动化部署工作。

iPipe:持续交付工具

Why iPipe

优势 详细说明
高效 分布式构建,并发不排队;串行、并行、定时多种模式支持;自动日志分析,快速定位异常
强大 集成多种应用测试服务,开箱即用;一键部署主流云商;灰度发布、A/B验证多种部署支持;监控、反馈,实时了解系统运行情况

产品功能

  • Check-in编译
  • 持续集成
  • 产品仓库
  • 一键部署到云端
  • 移动应用测试

使用方式

以下一iPipe为例,简单了解一下平台如何使用。

iPipe + Jenkins

与Jenkins的集成方式,提供iPipe的Jenkins插件:iPipe-Agent
在iPipe上创建job
DevOps落地实践:BAT系列:CICD:iPipe vs CCI_第3张图片

自动化构建

DevOps落地实践:BAT系列:CICD:iPipe vs CCI_第4张图片

代码评审

DevOps落地实践:BAT系列:CICD:iPipe vs CCI_第5张图片

整体设定的yaml文件

Image:
    type : default
BeforeBuild:
    script : ./before_build.sh
Build:
    script : ./build.sh
AfterBuild:
    script : ./after_build.sh
Package:
    script : ./check_artifact.sh
    artifacts:
        name : waimai_fe
        version : $COMMIT_ID-$BUILD_ID
        files : [./ci.yml, ./build.sh]

格式说明
Image:
    type : 指定编译环境标签, 必填字段。默认标签是default, 任何企业均可指定使用。企业还可以拥有专有的编译环境标签,专有标签为企业专属所有。

BeforeBuild: // 编译前
    script : 指定编译前要运行脚本, 可选字段。该脚本的路径以代码根目录为起始的相对路径

Build: // 编译中
    script : 指定编译阶段要运行脚本, 可选字段。该脚本的路径以代码根目录为起始的相对路径

AfterBuild: // 编译后
    script : 指定编译完成后要运行脚本, 可选字段。该脚本的路径以代码根目录为起始的相对路径

Package:
    script : 指定将编译结果打包时要运行脚本, 可选字段。该脚本的路径以代码根目录为起始的相对路径. 具体的打包动作由编译系统自动完成,该脚本不负责具体的打包工作。
    artifacts:
        name : 指定编译结果压缩包的名称
        version : 指定编译结果压缩包的版本,支持$COMMIT_ID, $BUILD_ID两者的任意组合, 并用'-'连接. COMMMIT_ID 表示git 仓库commit id, $BUILD_ID 表示构建ID.
                  支持格式: $BUILD_ID, $COMMIT_ID, $BUILD_ID-$COMMIT_ID, $COMMIT_ID-$BUILD_ID
        files : 指定具体的产出文件路径,多个文件逗号分割。每个路径均以代码根路径起始的相对路径

情况说明:
       name 和version 全部为空时,表示只编译,不打包。
       name 和version 只要有一个不为空,则进行打包操作。
       version 字段只支持$BUILD_ID, $COMMIT_ID两个内置变量,必须以$开头, 两个都存在时必须以'-'连接,不支持其他符号进行连接
       files 中多个文件路径必须以逗号分割, 不分割默认是一个文件路径

持续交付

DevOps落地实践:BAT系列:CICD:iPipe vs CCI_第6张图片

总结

无论是百度还是腾讯,都很好的利用了自身的体量和平台的优势,使得云平台的用户使用起来更加顺畅,更能够集中精力与业务开发。除了一键部署,而iPipe也明确的提出了持续部署中的灰度发布和A/B验证部署方式的支持。但是CI/CD可能遇到的情况非常复杂,比如云和非云,公有云和私有云的混合构成,然后多种编程语言,多种操作系统,不同的中间件,是否依然能够支持,或者能够支持到什么程度,没有得到详细的验证,如果自动编译以Maven为中心的构成,则很有可能集中于java系的应用程序开发,具体在使用的时候这些都需要进一步的进行考察。

你可能感兴趣的:(DevOps,DevOps自动化工具)