`
kidiaoer
  • 浏览: 824785 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
文章分类
社区版块
存档分类
最新评论

不进行持续集成的理由

阅读更多
不进行持续集成的理由:

    - 硬件花费

    对于大多数的团队来说,持续集成服务器不需要运行在一台性能异常强大的机器上,使用一台开发机器加一个指示灯(在构建失败时变红)已经足够了,硬件的成本在不断的下降,和开发团队不断修复回归测试发现的缺陷,编译失败,延迟发布比起来,这个投资应该是非常划算的。

    - 管理开销

    目前的持续集成服务器已经比较成熟,并且有许多免费的产品(如CruiseControl)可以选择。这些服务器不论是运行还是配置都非常简单。开发团队可以根据熟悉的编程语言选择相关产品,以CruiseControl为例,分别有CruiseControl.rb (Ruby), CruiseControl.net (.Net), CruiseControl(Java)可以进行选择。这样开发团队可以在没有系统管理员的清况下,自行维护持续集成服务器。

    - 减慢了开发者提交的速度

    开发者花10分钟进行测试,节省了整个团队修复构建的时间,免去了不必要的交流成本,节省了修复bug的成本, 大大减少了延迟发布的可能。

    - 学习自动化测试

    不要重复你自己! 花半天学习Ant, Maven, Shell脚本比每天花半个小时手工测试要有趣得多,引入自动化测试,节省的不仅仅是个人的时间,整个团队效率也因此提高。

    让持续集成过程更强大:

    - 流水线构建

    作为持续集成实践的一部分,在完成代码编译后,必须将软件部署到测试或者产品环境中,在现代软件构建过程中,部署不再仅仅是将某个2进制文件拷贝到文件系统中,它通常包括了部署以及对于应用本身、数据库、Web容器等进行配置的过程。在进入产品环境前,软件通常会经过开发以及测试人员在开发环境,QA环境,性能测试环境,模拟产品环境的重重测试。由于环境以及操作的复杂,大量的手工劳动譬如修改配置文件在这个时候被引入进来。

    流水线构建的出现就是为了解决上述问题:一个RC版本需要通过所有的测试阶段,在每一个阶段中,产品都会被测试并且进行某种形式的修改来准备下个阶段的测试。产品在管道中不断的前进,并且被不断检验,组装,修改。如果产品能够成功的到管道的终点,它就可以被认为是一个成功的RC版本。

    流水线构建被划分为提交阶段, 验收阶段, 性能测试阶段/手工测试阶段, 产品部署等4个阶段。

    提交阶段:是管道的第一个部分。当开发者提交代码后,产品就进入这个阶段。在提交阶段,代码被编译,相关的单元测试被运行。这个阶段所需要的测试时间必须尽量短,开发者需要等到这个阶段成功完成才可以开始下一个任务。这个阶段不是通过测试类型教条划分的,我们应该根据哪些测试可以被快速运行并且帮我们发现大多数常见的问题来划分测试。譬如,在我现在参与的项目中存在JUnit,JWebUnit , JSUnit, Selenium 测试等,Selenium 花费的时间相对长,而且运行JUnit, JWebUnit以及JSUnit在通常清况下,已经可以帮助我们发现大多数的问题,那么它们将成为我们能否能通过提交阶段的依据。

    验收阶段: 在很多清况下,我们的软件可以通过单元测试,功能测试,但是这并不意味着有了一个成功、可用的软件,因为它也许与我们的业务需求背道而驰,验收测试用于验证软件是否更够满足业务需求,体现商业价值。验收测试通常运行在开发者本地测试相似的环境中(使用相同的OS, JDK等)。只有能够通过验收阶段的产品才有可能成为RC版本的软件. 在这个阶段,我们应当使用提交阶段的构建结果。而不是重新编译,打包。(想象一下,软件正在这个管道中移动,我们要做的是继续组装而不是拆卸),例如,提交阶段结束后,一个war被拷贝至文件系统某个特定的目录,而验收测试服务器通过扫描目录发现更新并通过使用它进行Selenium 测试。

    在进入下一个阶段前,我们需要通过部署阶段。在这个阶段,我们需要初始化测试环境,并根据测试环境的需求,修改配置文件。初始化测试环境对于整个构建管道非常重要,它确保了产品在确定的环境中运行,减小分析问题的难度。这正是工业自动化的精髓所在:尽量的在生产过程中,通过自动化去除不确定因素。初始化测试环境通常是通过还原镜像文件来进行,我们根据目标测试环境制作不同的镜像文件,并且在部署还原镜像文件。这个阶段可能是自动的也可能是手动的。当然,原则是尽量自动化进行,但是如果难度过大,手工还原也可作为一种妥协。

    性能测试和手工测试:它们可以同时在不同的服务器上进行。自动化测试只能阻止已知缺陷不会再出现。但是无法验证测试用例之外的情况。手工测试或者叫做探索测试 正是在这种情况下进一步的测试软件的行为。

    产品部署 :整个管道的最终阶段,验证软件是否能够真正的安装并运行在目标产品环境中。

    - 分布式构建

    某些持续集成工具(如CruiseControl)支持合成构建模式,即当且仅当所有子构建全部成功,主构建才会成功。分布式构建(以 CruiseControl为例)就是建立在JINI以及合成构建的基础上。通过使用分布式构建,我们可以大大缩短构建时间以及在不同的环境下对产品进行构建。

    分布式构建通过将主构建分为若干可以同时进行构建的模块来加快速度,譬如、某项目可能由:登录模块测试(10分钟),付款模块测试(20分钟),管理模块测试(20分钟)。在这种清况下,我们可以部署4个CruiseControl实例(一个作为主构建,其余三个作为子构建分别重复安装目标项目)。子构建分别运行不同模块的测试,而主构建负责收集根据子构建成功与否决定整个构建是否通过。与上述的实践相似,通过将实例部署在不同环境中(Windows, Linux, Unix等),我们也可以验证产品是否可以在不同环境中进行构建。

    关于分布式构建,ThoughtWorks发布了一份详细的文档指导开发者如何一步步进行配置,在此不再赘述。

    总结:

    持续集成是软件开发一个重要的实践,通过持续集成,我们能够更早的发现问题,更快的解决问题,同时大大减少了构建过程中不确定性,提高团队的生产效率。当然,持续集成实践不是孤立的,它与其他的软件开发实践例如测试驱动等紧密相关。正确使用持续集成实践将帮助我们在一个轻松的环境中快速开发,发布高质量的产品。

    参考:

    The Deployment Pipeline

    Continous Integration

    CruiseControl Reference

    Using distrib from the CruiseControl contrib
分享到:
评论

相关推荐

    使用Hudson持续集成 ppt

    - **定义**:持续集成(Continuous Integration, CI)是一种软件开发实践,开发者经常将代码提交到共享存储库,每次提交后都会自动构建并进行自动化测试,以尽早发现集成错误。 - **核心价值**: - **持续反馈**:...

    xmljava系统源码-Jenkins-automation:Jenkins持续集成自动化发布。如何配置Jenkins,如何构建发布分支

    xml java系统源码 title date tags categories Ansible + Jenkins+Maven+Nginx搞定自动发布,构建程序的持续集成平台 2016-09-12 ...二、为什么Jenkins能帮助我们进行持续集成 理由有如下几点: 1、Jenkins

    百度前端集成解决方案

    通过引入自动化工具,如构建工具、测试框架和持续集成服务,可以自动完成代码的编译、压缩、测试等繁琐工作,使得开发者能够专注于业务逻辑的编写,而不是被低效的手动操作所困扰。例如,百度内部的FIS项目,正是...

    集成电路及微机械加工技术

    集成电路是现代信息技术的核心组成部分,它的制造过程涉及到一系列复杂的微机械加工技术。集成电路的工艺流程和技术发展具有严格的规律...随着科技的不断发展,我们有理由期待更加先进、高效和智能的集成电路产品问世。

    2022级集成电路设计与集成系统专业人才培养方案.pdf

    随着全球科技的迅速发展,集成电路设计与集成系统作为现代电子信息...通过这样的教育体系,我们有理由相信,我国集成电路产业将在未来持续培养出大量优秀人才,为实现产业的高质量发展和国家的科技进步作出重要贡献。

    系统集成项目管理工程师案例分析考前学习资料

    - **缺少正式的新产品研发项目建议书**:在没有明确的产品研发项目建议书的情况下进行可行性研究可能会导致目标不清晰、方向不确定等问题。 - **可行性研究工作不充分**:尤其是缺乏技术可行性分析和技术论证,可能...

    智能建筑系统集成的探讨.docx

    智能大厦的系统集成不仅仅是设备的堆砌,而是通过技术整合,实现信息共享和资源共享,从而达到“1+1>2”的效果。 智能建筑系统集成通常分为几个阶段,从最初的子系统功能集成,逐步发展到控制网络集成,最终实现...

    电子政务-一种集成电路专用焊接器.zip

    而集成电路作为现代信息技术的核心,其在电子政务中的应用更是不可或缺。本篇文章将重点探讨一种集成电路专用焊接器在电子政务领域的应用及其重要性。 集成电路(Integrated Circuit,简称IC)是现代电子设备的基础...

    工业化集成住宅.docx

    《工业化集成住宅——技术革新与优势解析》 工业化集成住宅,作为现代建筑行业的一大创新,以其高效、节能、...在未来,随着科技的不断进步,我们有理由相信,产业化集成住宅将为人们提供更加舒适、绿色的生活空间。

    CAICV:2024汽车玻璃集成UWB数字钥匙发展研究白皮书.pdf

    在国际上,宝马、奥迪等豪华品牌较早引入了数字钥匙技术,并持续进行技术创新;在国内,诸如比亚迪、蔚来等新势力车企也纷纷推出了各自的解决方案。 ##### 软件系统架构介绍 汽车数字钥匙的软件系统通常包括前端...

    电子政务-改进的集成电路元件包装管塞头.zip

    电子政务作为现代社会中政府职能的重要组成部分,利用现代信息技术尤其是...随着技术的不断进步,我们有理由相信,电子政务将继续在集成电路行业中扮演越来越重要的角色,推动整个行业向更高效、更智能化的方向发展。

    抽号器第三版(集成帮助功能版)

    在当今信息化时代,各种数字...在未来的发展中,我们有理由相信,《抽号器第三版(集成帮助功能版)》会不断进步,持续引领抽号工具的新潮流,满足更多用户的需求,为各种活动的公平、公正和顺利进行做出更大的贡献。

    医院建设发展中对医疗信息化集成平台的运用分析.pdf

    在当今信息化时代的洪流中,医疗行业也迎来了前所未有的变革...随着信息技术的不断进步和医疗健康行业的持续发展,我们有理由相信,医疗信息化集成平台的应用在未来将更加广泛和深入,为医院提供更加强大的信息化支持。

    2021年薪酬报告系列之高科技互联网软件与系统集成行业薪酬报告薪酬调查.pdf

    最后,报告对未来薪酬趋势进行了预测,认为随着数字化转型的持续深化,以及国家对科技创新和人才培养的进一步支持,高科技互联网软件与系统集成行业的薪酬水平预计将继续保持增长。同时,随着技术的不断发展和行业...

    一体化集成电子信息系统体系发展研究.pdf

    在现代信息化战争条件下,电子信息系统的功能和技术发展是战略决策与作战...随着信息科技的不断进步,我们有理由相信,未来电子信息系统将更加智能化、集成化和高效化,为国家的军事和民用领域提供更加坚强的技术支撑。

    智能装备系统集成及应用.rar

    智能装备系统集成及应用是现代工业生产中的一个重要领域,它涉及到自动化、信息化、智能化等多个方面的技术...随着科技的进步,我们有理由相信,未来的智能装备系统集成将更加成熟,为各行各业带来更多的变革和机遇。

    行业-电子政务-用于感测装置的集成无源电路元件.zip

    1. 信号调理:集成无源电路元件可以对传感器输出的弱信号进行放大、滤波,降低噪声,提高信号质量,确保后续数据处理的准确性。 2. 数据采集:在数据转换器前端,集成无源电路元件有助于稳定输入电压,提高ADC(模拟...

    关于城市轨道交通工程自动化监测智能集成技术的应用.rar

    3. 数据采集与处理:高精度传感器持续监测轨道、隧道、桥梁等关键部位的状态,收集的数据经过预处理后,运用人工智能算法进行模式识别和异常检测,提供决策依据。 4. 预警与应急响应:当监测数据超出安全阈值时,...

Global site tag (gtag.js) - Google Analytics