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

Posted firsttry

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了DevOps落地实践 BAT系列 CICD iPipe vs CCI相关的知识,希望对你有一定的参考价值。

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

CCI持续集成

为开发者提供支持多种编程语言的编译构建服务,包含定时/手动启动构建、查看构建结果及日志、支持快速分发交付、可扩展的自动化测试等功能,为项目的持续集成体系提供上游基础服务,提升项目研发效率。
技术分享图片

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
技术分享图片

自动化构建

技术分享图片

代码评审

技术分享图片

整体设定的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 中多个文件路径必须以逗号分割, 不分割默认是一个文件路径
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41

持续交付

技术分享图片

总结

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

再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://www.cnblogs.com/captainbed





以上是关于DevOps落地实践 BAT系列 CICD iPipe vs CCI的主要内容,如果未能解决你的问题,请参考以下文章

cicd与devops区别是啥?

优维DevOps系列沙龙全回顾:DevOps+SRE落地实践+DevOps最后一棒

切忌一步到位,谈谈DevOps实施落地

记录一次成功CICD完整亲身实践从此踏进入Devops大门

DevOps 在公司项目中的实践落地

devops实践: teamcity实现持续集成