Jenkins 持续集成 概念(学习笔记二十六)

简介: 持续集成:提交、测试、构建、测试、部署前不久接触了持续集成(Continuous Integration,CI)。一、持续集成是什么首先说说“集成”的概念。

持续集成:提交、测试、构建、测试、部署

前不久接触了持续集成(Continuous Integration,CI)。

一、持续集成是什么

首先说说“集成”的概念。在实际的软件开发中,常常会发生两种情境:

1.几个项目组对同一个系统的不同功能分别开发,最终需要将所有的软件功能集成到一个系统中;

2.软件开发出来后,由于种种原因要进行更新升级。

上述两种情境其实就是集成的含义。

了解了“集成”的概念之后,“持续集成”的概念就好理解了。顾名思义,就是比较频繁地进行【自动集成】这个环节。(为什么要自动集成呢?请参考本文第三部分:什么情况要用到持续集成)

二、使用持续集成能有什么好处

从持续集成的概念很容易看出,它的核心思想是“步步为营”,这种思想带来如下好处:

当测试失败或者出现错误时,允许及时回滚代码。

不断测试修复集成问题,避免临时抱佛脚。

预警问题和冲突代码。

所有的代码变化可以及时得到测试。

及时向开发人员反馈他们编写代码的功能、质量和对系统的影响情况。

频繁的代码检查促进开发人员写出模块化和简洁的代码。

项目任何时候都保持在可运行状态。

---------------------------------------

有好处自然也会有劣势存在,这里简要说一下:

强大的测试套件和编写良好的测试代码才能发挥自动化测试的优势。

一定的硬件成本(小项目忽略不计)。

初始部署的人力成本。

三、什么情况要用到持续集成

集成软件的过程不是新问题,如果项目开发的规模比较小,软件集成不是问题。但是如果项目很大,需要不断添加新功能,则需要常常集成,这个时候就需要用到持续集成了。

四、持续集成如何实施

持续集成的实施,有不少说法,我比较认同阮一峰老师的说法(点击查看)。

为了方便查看,我直接引用了阮老师的关于实施的内容:

----------------------------------------------------------------------------------------------------------------------------------------

1 提交

流程的第一步,是开发者向代码仓库提交代码。所有后面的步骤都始于本地代码的一次提交(commit)。

2 测试(第一轮)

代码仓库对commit操作配置了钩子(hook),只要提交代码或者合并进主干,就会跑自动化测试。

测试有好几种。

单元测试:针对函数或模块的测试

集成测试:针对整体产品的某个功能的测试,又称功能测试

端对端测试:从用户界面直达数据库的全链路测试

第一轮至少要跑单元测试。

3 构建

通过第一轮测试,代码就可以合并进主干,就算可以交付了。

交付后,就先进行构建(build),再进入第二轮测试。所谓构建,指的是将源码转换为可以运行的实际代码,比如安装依赖,配置各种资源(样式表、JS脚本、图片)等等。

常用的构建工具如下。

Jenkins

Travis

Codeship

Strider

Jenkins和Strider是开源软件,Travis和Codeship对于开源项目可以免费使用。它们都会将构建和测试,在一次运行中执行完成。

4 测试(第二轮)

构建完成,就要进行第二轮测试。如果第一轮已经涵盖了所有测试内容,第二轮可以省略,当然,这时构建步骤也要移到第一轮测试前面。

第二轮是全面测试,单元测试和集成测试都会跑,有条件的话,也要做端对端测试。所有测试以自动化为主,少数无法自动化的测试用例,就要人工跑。

需要强调的是,新版本的每一个更新点都必须测试到。如果测试的覆盖率不高,进入后面的部署阶段后,很可能会出现严重的问题。

5 部署

通过了第二轮测试,当前代码就是一个可以直接部署的版本(artifact)。将这个版本的所有文件打包( tar filename.tar * )存档,发到生产服务器。

生产服务器将打包文件,解包成本地的一个目录,再将运行路径的符号链接(symlink)指向这个目录,然后重新启动应用。这方面的部署工具有Ansible,Chef,Puppet等。

6 回滚

一旦当前版本发生问题,就要回滚到上一个版本的构建结果。最简单的做法就是修改一下符号链接,指向上一个版本的目录。

----------------------------------------------------------------------------------------------------------------------------------------

需要说明的是,其中重要的是第3步——构建,它是持续集成实施的核心步骤。目前使用量比较大的是Jenkins,读者可以参考相关Jenkins的博客内容。

五、致谢

非常感谢阮一峰老师提供的视角,大学时期曾买过阮老师的书籍《如何变得有思想》,他的思想及写作风格让我大受裨益。

六、参考链接

持续集成是什么? - 阮一峰的网络日志 http://www.ruanyifeng.com/blog/2015/09/continuous-integration.html?utm_source=tuicool

集成开源系统实现自动化构建、代码质量评估、项目信息统计 - 孤剑 - 博客园http://www.cnblogs.com/AloneSword/archive/2011/11/05/2236950.html

Welcome to Jenkins CI! | Jenkins CI http://jenkins-ci.org/

目录
相关文章
|
8月前
|
机器学习/深度学习 算法 前端开发
集成电路设计:从概念到实现的完整解析优雅草卓伊凡
集成电路设计:从概念到实现的完整解析优雅草卓伊凡
328 2
集成电路设计:从概念到实现的完整解析优雅草卓伊凡
|
jenkins Devops Java
DevOps实践:Jenkins在持续集成与持续部署中的价值
【10月更文挑战第27天】在快速发展的软件开发领域,DevOps实践日益重要。Jenkins作为一款流行的开源自动化服务器,在持续集成(CI)和持续部署(CD)中扮演关键角色。本文通过案例分析,探讨Jenkins在Java项目中的应用,展示其自动化构建、测试和部署的能力,提高开发效率和软件质量。
436 2
|
9月前
|
传感器 供应链 物联网
农业单亩价值创造功能技术集成的概念与内涵
农业单亩价值创造的技术集成,通过系统性创新打破传统单一模式,融合现代科技与生态理念,提升资源效率、经济效益和生态价值。其核心在于技术协同,实现精准农业、智能装备和生物强化等多维联动,推动经济、生态和社会价值统一。同时,注重资源集约化与循环化利用,延伸产业链并升级价值链,从短期高产转向长期可持续发展。政策与制度创新支撑技术普惠,未来需因地制宜解决技术适配性和成本收益平衡问题,重塑农业评价体系,实现高质量发展。
|
12月前
|
监控 jenkins Shell
jenkins结合gitlab实现CI(持续集成)
通过本文的介绍,我们详细了解了如何结合Jenkins和GitLab实现持续集成。从环境准备、插件配置到Pipeline任务创建和CI流程监控,每一步都提供了详细的操作步骤和示例代码。希望本文能帮助开发者快速搭建起高效的CI系统,提高项目开发效率和代码质量。
1182 9
|
Java jenkins 持续交付
Jenkins集成Maven
通过以上步骤,可以在Jenkins中成功集成Maven,实现自动化构建和部署。通过定时构建、SCM轮询等方式,可以确保代码库中的最新变更能够及时构建和测试,提高开发效率和代码质量。这种集成方式在实际项目中具有广泛的应用前景,能够显著提升团队的协作效率。
443 8
|
监控 jenkins Linux
从 Jenkins 持续集成出发:探究如何监控员工电脑屏幕
Jenkins 在企业信息化管理中用于自动化构建、测试和部署,提高开发效率。本文讨论了其重要性,并从技术角度探讨了屏幕监控的可能性,但明确反对非法监控,强调应合法合规地管理企业和尊重员工隐私。
258 12
|
运维 jenkins Java
Jenkins在持续集成与持续部署中的价值
Jenkins在持续集成与持续部署中的价值
|
jenkins Devops 测试技术
DevOps实践:Jenkins在持续集成与持续部署中的价值
【10月更文挑战第26天】随着DevOps理念的普及,Jenkins作为一款开源自动化服务器,在持续集成(CI)与持续部署(CD)中发挥重要作用。本文通过某中型互联网企业的实际案例,展示了Jenkins如何通过自动化构建、持续集成和持续部署,显著提升开发效率、代码质量和软件交付速度,帮助企业解决传统手工操作带来的低效和错误问题。
522 4
|
jenkins Shell 持续交付
Jenkins持续集成GitLab项目 GitLab提交分支后触发Jenkis任务 持续集成 CI/CD 超级详细 超多图(二)
Jenkins持续集成GitLab项目 GitLab提交分支后触发Jenkis任务 持续集成 CI/CD 超级详细 超多图(二)
358 0
|
持续交付 jenkins Devops
WPF与DevOps的完美邂逅:从Jenkins配置到自动化部署,全流程解析持续集成与持续交付的最佳实践
【8月更文挑战第31天】WPF与DevOps的结合开启了软件生命周期管理的新篇章。通过Jenkins等CI/CD工具,实现从代码提交到自动构建、测试及部署的全流程自动化。本文详细介绍了如何配置Jenkins来管理WPF项目的构建任务,确保每次代码提交都能触发自动化流程,提升开发效率和代码质量。这一方法不仅简化了开发流程,还加强了团队协作,是WPF开发者拥抱DevOps文化的理想指南。
322 1

推荐镜像

更多