作为DevOps流程中的一个重要组成部分,持续集成(CI)的目标是对开发团队的代码进行集成,包括代码的构建、单元测试与集成测试的执行,以及生成执行结果的报表等等。CI使开发团队无需将时间浪费在处理代码冲突的问题上,因此很多人将其视为敏捷软件开发的奠基石。

CI与持续部署(CD)过程通常是紧密联系在一起的。CD过程通过在管道中定义的步骤将由CI过程所生成的结果部署至集成、预发布乃至生产环境中。由于整个CD过程是“持续的”,因此一旦有代码签入源代码控制系统,后续过程就会自动进行测试、对代码进行构建、并将构建结果部署至目标环境中。它的优点显而易见:一方面,开发者可快速地收到bug与故障的通知,形成快速的反馈循环。另一方面,客户也将更快地使用你的新特性。

近日,Vassili van der Mersch在一篇博客文章中对各种环境中的CI工具进行了详细的比较,并分析了CI工具的未来发展。在后续的文章中,作者还将继续分析DevOps中的另一重要内容,即配置管理。

传统的CI工具

第一个正规的持续集成工具是于2001年所推出的CruiseControl,这是一个基于Java开发的开源软件。除了持续构建流程之外,它还提供了邮件通知、Ant以及对各种源代码控制系统的支持,并推出了支持.NET与Ruby的移植版本。尽管Jenkins后来居上,成为第一个得到广泛应用的CI工具,但CruiseControl已经具备了一个CI工具的基本功能,为CI过程的推广做出了很大的贡献。

Jenkins的出现与发展颇有传奇色彩,它的前身是由一位来自Sun公司的开发者川口浩介(Kohsuke Kawaguchi)于2004年开发的一个基于Java的CI工具Hudson。经过三/四年的发展后,它逐渐超越CruiseControl成为了最流行的CI工具。但自从Oracle收购了Sun之后,希望将Hudson作为收费的商业工具进行开发。以川口为首的开发者社区则决定以Jenkins的名义继续免费版本的开发。有趣的是,Hudson与Jenkins的开发者各自将对方视为自己的分支版本,而将自身视为正统。在2013年后,Jenkins的发展势头已有超越之势,它的每日提交次数远远地超越了Hudson,如今已成为市面上最流行的CI工具。

早期的Jenkins与其他传统CI一样,只支持本地托管。而现在已经有一些云计算平台推出了基于Jenkins的SaaS方案。这方面比较突出的有CloudBees,它所提供的方案是一种集成了CI与CD的混合方案,可通过Docker Pipeline插件提供对Docker容器的支持。

除了Jenkins之外,其他一些流行的CI工具还包括由JetBrains推出的TeamCity,以及由Atlassian推出的Bamboo等等。这些CI工具基本都提供了以下功能:

对源代码控制系统的支持,例如Git、Subversion、TFS等等。可以在代码控制的主线发生代码提交时自动触发后续的一系列步骤,例如构建、测试与部署等等。 对依赖管理工具的支持,如Java的Maven、NodeJS的NPM、Ruby的Gem,以及.NET的Nuget等等。 对各种类型测试的支持。早期的CI只支持单元测试,即单个对象或组件的功能验证。随后加入了对集成测试的支持,即对组件之间的通信与交互进行难。尽管如此,这还不足以验证系统确实按照用户期望的方式进行工作。因此现代化的CI工具开始支持功能性测试,将原先的手工测试替代为基于Selenium等工具的自动化测试。

云计算环境中的CI工具

曾在大规模企业中尝试过CI实践的开发者非常了解:代码的构建与测试的执行是一种非常消耗资源的操作,如果有多个团队使用同一个CI平台,那么这种情况将进一步加剧。近几年来,软件团队逐渐厌倦了本地托管的CI系统对时间与精力的要求。而基于云计算平台的SaaS解决方案的出现快速地弥补了这方面市场的缺失。

Travis CI是一个基于GitHub API所打造的托管CI服务,使用Travis CI有一个先决条件,即源代码需要在GitHub进行托管。Travis CI通过webhook对GitHub代码仓库中的各种变化进行响应,例如代码提交或pull request等等。Travis CI也依赖GitHub提供的服务对用户和组织进行认证。

使用基于云环境的CI系统让开发者得以从对本地CI系统的安装、配置过程中解脱,不必再关注于基础设施和用户认证与授权方面的问题。此外,由于大多数SaaS方案都提供了对应的API,因此整个工作流都可以实现API驱动。

基于云环境的CI系统还有另一大优势,他们通常会提供更多的测试功能,例如对不同浏览器与操作系统组合条件的测试。例如Travis就支持在Linux、Mac和Windows系统上的测试,并支持PHP、NodeJS、Go和C等各种语言。

用于移动应用的CI工具

随着智能手机的日益普及,移动应用的数量也在不断增长。但由于移动应用与Web应用相比有一些特别之处,例如它的测试与发布方式,以及完全不同的依赖管理机制,因此移动应用对于构建、测试及部署流程提出了完全不同的要求,这是传统的CI工具力所不及的。好在如今已经有几家主流的CI提供商实现了支持移动应用的CI工具,例如CircleCI已经提供了对iOS应用的支持。

移动应用的测试与Web应用具有很大的差别,Web应用的客户端多数集中在一些主流的浏览器与操作系统上,而移动应用的客户端往往是千差万别的,特别是在Android平台上。某些测试框架,例如Espresso以及Appium能够自动替你解决许多困难。而像Crashlytics与HockeyApp这样的工具除了内置的CI功能之外,还能够自动生成应用崩溃的报告,为开发者进行问题诊断提供充分的上下文。

而由于移动客户端的多样性,以集中化的方式进行所有测试的方式是不太实际的。因此,移动开发社区更推崇beta测试的方式,通过TestFairy或TestFlight等工具将潜在的新版本发布给beta测试人员。

移动应用的另一个独特之处在于它的发布方式,通常需要经过漫长而繁琐的审核流程才可发布至对应的应用商店。这不仅降低了持续交付的速度,还不得不在流程中引入各种人工步骤,使全自动化的流程无法实现。

为此,像Fastlane这样的工具可实现将应用审核流程中的大部分元素实现自动化,例如为新应用进行屏幕截图及处理认证等信息。可结合Jenkins等CI工具以完善整个工作流。

CI工具的未来

CI与CD过程如今已成为现代化应用开发中一个并不可少的元素,绝大多数开发团队在软件项目中都需要设计一个完善的CI与CD工作流。

而CI的发展并不会停下脚步,它仍处于高速的发展中。在对Web及移动项目支持的基础上,未来几年之内,我们将看到CI在其他类型的开发中的应用,例如智能手表、智能汽车以及物联网中,甚至是在虚拟现实与生物科技项目中的应用。

CI过程目前所面临的一个挑战在于在开发环境中执行的自动化测试与生产环境之间总是存在着或多或少的差别。随着近来年以Docker为代表的容器化技术在(微)服务系统中的广泛应用,CI过程也从容器的使用中受益匪浅。Docker的高可移植性使多个CI提供商开始拥抱Docker。举例来说,CircleCI就支持基于容器的应用,而CodeShip近期也推出了Jet,这是一个对Docker应用进行测试与部署的解决方案。

本文转自d1net(转载)

以持续集成工具实现DevOps之禅相关推荐

  1. 【云原生 • DevOps】一文掌握持续集成工具 Jenkins

    目录 一.持续集成工具 Jenkins 介绍 1. 什么是持续集成 2. Jenkins 介绍 二.Jenkins 的安装与部署 1. 安装 Jenkins 2. 本地访问 Jenkins 3. 插件 ...

  2. python持续集成工具_21 个好用的持续集成工具,总有一款适合你

    原标题:21 个好用的持续集成工具,总有一款适合你 市场上持续集成工具众多,找到一个合适的工具并非易事,下面介绍了 21 个比较受欢迎的 CI 工具,并附上了下载链接. 1. Buddy 对 Web ...

  3. 21 个好用的持续集成工具,总有一款适合你

    市场上持续集成工具众多,找到一个合适的工具并非易事,下面介绍了 21 个比较受欢迎的 CI 工具,并附上了下载链接. 1. Buddy 对 Web 开发者来说,Buddy 是一个智能的 CI/CD 工 ...

  4. 敏捷开发,持续集成/交付/部署, DevOps总结

    文章目录 敏捷开发入门教程 一.迭代开发 二.增量开发 三.敏捷开发的好处 3.1 早期交付 3.2 降低风险 四.如何进行每一次迭代 五.敏捷开发的价值观 六.十二条原则 七.参考链接 持续集成/交 ...

  5. 2020年10种最佳持续集成工具

    技术正呈指数级增长,并且要参与其中,组织别无选择,只能采用技术.谈论"技术"基本上意味着创建"更快,更方便"和"定性"的解决方案.为了跟上高 ...

  6. 持续集成与持续部署(三)——实现持续集成的效率工具对比之Jenkins、Travis CI、Circle CI和其他持续集成工具

    持续集成与持续部署(三)--实现持续集成的效率工具对比之Jenkins.Travis CI.Circle CI和其他持续集成工具 效率工具对比 点击查看效率工具 1. Jenkins Jenkins, ...

  7. 21 个好用的持续集成工具

    市场上持续集成工具众多,找到一个合适的工具并非易事,下面介绍了 21 个比较受欢迎的 CI 工具,并附上了下载链接. 1. Buddy 对 Web 开发者来说,Buddy 是一个智能的 CI/CD 工 ...

  8. jenkins 忘记密码_持续集成工具Jenkins 在CentOS系统下安装

    一.Jenkins简介 Jenkins是一个开源的持续集成工具,用于持续.自动的构建.测试.发布项目.Jenkins使用Java开发,可与版本管理工具集成使用. Jenkins支持UI操作来部署流水线 ...

  9. 中小型研发团队架构实践:高效率、低风险,一键发布并测试的持续集成工具Jenkins...

    一.Jenkins 简介 \\ 当每月发布次数变得越来越多时,如超过 200 次,发布工作人员的工作量会翻倍,此时由人工发布操作失误引起的风险会变得越来越大.为了提高项目的发布效率,也为了降低由人工操 ...

最新文章

  1. 也谈TDD,以及三层架构、设计模式、ORM……没有免费的午餐,选择了,必付出代价...
  2. 在 Spring中 创建 JavaBean
  3. 利用git 进行多人协作开发
  4. [JAVA] String常用方法
  5. VTK:阴影灯用法实战
  6. python是如何登上编程语言排行榜榜首的
  7. Web Client Software Factory系列(4):数据绑定和ObjectContainerDataSource控件
  8. 安装linux可是c盘文件夹失败,虚拟机安装linux系统,会对物理的磁盘有影响吗?怎样保证安全,谢了!...
  9. js字符串分割处理的几种方法
  10. PID算法详解及实例分析
  11. android 截屏分享权限,android 截屏+保存图片+权限
  12. 【Love2d从青铜到王者】第十一篇:Love2d之图像(Images)
  13. 全智通A+常见问题汇总解答—A+人脉关系中的新建权限取消掉后,保存权限,权限依然存在
  14. 20210706 为什么edge无法修改主页?或者启动后两个页面?
  15. 【shareX】自定义图片上传-基于tu.my最新版API
  16. 天池竞赛-金融风控-task1
  17. 用unity开发贪吃蛇,勾起我童年乐趣的小游戏
  18. oracle 朱志辉_阿里云自定义镜像
  19. Noise2Noise的一些学习总结
  20. 聚类标准误(cluster standard errors)是什么,什么情况下需要聚类,控制了固定效应(fixed effect)还需要聚类吗?

热门文章

  1. Spark 数据挖掘 - 利用决策树预测森林覆盖类型
  2. nginx+tomcat 反向代理 负载均衡配置
  3. 第六章、epub文件处理 -- 解析container文件与.opf文件
  4. 工作多年的.NET程序员,是否建立了自己的开发知识库?分享制作电子书的经验...
  5. PyTorch | Tensor、Numpy、Variable之间的转换
  6. java 模型 视图,部分视图模型
  7. MySQL高级 - 锁 - MyISAM表锁 - 写锁
  8. MySQL高级 - 查询缓存 - 失效场景
  9. MyBatis 缓存详解-什么时候开启二级缓存?
  10. Spring MVC 使用优化建议-缓存URL