构建高质量的持续交付体系

简介: 前面的文章,聊了软件工程的基础理论、项目管理、需求分析、架构设计、软件测试以及线上服务的质量保障。其中在架构设计和线上服务的质量保障中,我也提到了关于持续集成持续交付相关的内容。软件工程的本质是用工程化的方法去规范软件开发,让软件开发项目可以按时保质完成的同时且成本可控。

这是软件工程系列知识总结的第七篇文章,也是最后一篇。


前面的文章,聊了软件工程的基础理论、项目管理、需求分析、架构设计、软件测试以及线上服务的质量保障。其中在架构设计和线上服务的质量保障中,我也提到了关于持续集成持续交付相关的内容。软件工程的本质是用工程化的方法去规范软件开发,让软件开发项目可以按时保质完成的同时且成本可控


交付的软件产品除了质量之外,交付效率对团队来说也是很重要的一点,而持续高效的交付高质量的软件产品,更需要一个高效的持续交付技术体系支撑。


理解持续交付体系


无论是保障质量,还是提升效率,都需要某些持续的能力来支撑他们。


这种支撑能力,可以看作是一种工厂化的流水线能力,业内通常将其统称为持续交付。


从质量保障的角度总体来说,我将其分为:CI持续迭代-CI持续集成-CD持续发布-CO持续运营-CM持续度量


持续迭代Continuous Iteration)


技术是什么呢?技术是工具,技术服务于架构设计,架构设计服务于产品,产品服务于业务,业务服务于商业。


这里的持续迭代,更多指的是业务或者需求上的一种可持续的变化,通过需求不断变化来驱动,持续迭代软件产品,为用户提供更好的服务,达成商业价值变现。


持续集成(Continuous Integration)


持续集成可以帮助技术团队更加频繁的将代码更改合并到共享分支或"主干"中。一旦对应用所做的更改被合并,系统就会通过自动构建应用并运行不同级别的自动化测试(通常是单元测试和集成测试)来验证这些更改,确保这些更改没有对应用造成破坏。如果自动化测试发现新代码和现有代码之间存在冲突,CI 可以加快修复这些错误的过程


持续发布(Continuous Deployment)


这里的持续发布包括持续交付(Continuous Delivery)和持续部署(Continuous Deployment)。


完成 CI 中构建及自动化的测试流程后,持续交付可自动将测试通过的代码发布到存储库。持续交付的目标是拥有一个可随时部署到生产环境的代码库。在持续交付中,每个阶段都涉及测试自动化和代码发布自动化。在流程结束时可以快速的将应用部署到生产环境中。


对于一个成熟的 CI/CD 管道来说,最后的阶段是持续部署。作为持续交付的延伸,持续部署可以自动将应用发布到生产环境,持续部署在很大程度上都得依赖精心设计的测试自动化。持续部署意味着开发人员对应用的更改在编写后的几分钟内就能生效(假设它通过了自动化测试)。这更加便于持续接收和整合用户反馈。


所有这些 CI/CD 的关联步骤都有助于降低应用的部署风险,因此更便于以更快的节奏发布对应用的更改。不过,由于还需要编写自动化测试以适应 CI/CD 管道中的各种测试和发布阶段,因此前期建设需要很大的资源投入


持续运营(Continuous operation)


应用在生产环境发布后,需要持续的跟踪线上质量、用户反馈建议以及线上可能发生的一些问题或者故障。


所有线上的用户建议、可能发生的问题或者故障,其实从本质来说,和交付质量都息息相关。因此这里提出了持续运营,就是提倡质量的把控、验证、度量即使到了生产环境,也需要持续不断的将这套机制运行下去。


持续度量(Continuous measurement)


脱离数据讲质量是空中楼阁,从需求质量到交付质量整个周期中,将每个阶段的要做的事情,出现的问题,发生的风险以及结果都进行可量化的记录展示,然后从中进行分析评估,找到不足之处。这就是持续度量,需要持续的投入。


持续交付优势


  • 尽快暴露问题;
  • 极大提升效率;
  • 提升交付质量;
  • 降低项目成本;


持续交付体系工具


工具名称 工具作用
Git、SVN、GitLab、Coding 统一的源代码管理工具
testNg、pytest、sonar、selenium 单元/接口/UI自动化测试工具
Jenkins、Go CD、Travis CI、Pipelines 持续集成和持续部署工具


持续交付的前提是整个研发测试发布流程要做到高度自动化。要实现持续交付,项目一般需要满足这些条件:


  1. 代码构建的过程可以反复高频进行,且每次构建结果是一致稳定的;
  2. 所有环境配置信息都存于源代码管理工具中(现在有配置中心组件如Nacos/Apollo);
  3. 针对不同环境需要部署的代码包,需要自动编译和创建不同版本;
  4. 所有环境的构建编译部署发布步骤必须是自动化完成;


DevOps和持续交付的关系


持续交付要求代码可以反复高频的构建编译,代码包的测试部署发布需要自动化来完成,但传统的研发交付流程已经渐渐不适应当下的业务变化,因此才有了近几年的DevOps,甚至万物皆可Ops。


其实DevOps并不是一种岗位,可以理解为一种紧密协作的高效工作方式。无论是DevOps,还是所谓的TestOps,其实都指的是开发/测试和运维同学一起通过高效协作的方式来更快的构建、测试和发布软件。


DevOps的优势


以DevOps为例,当团队采取这种工作协作方式后,带来的好处如下:


  • 软件的构建测试和发布过程高度自动化;
  • 信息更加透明,交付质量更易于度量评估;
  • 跨团队和跨职能协作的效率和氛围会更好;


要实践DevOps,意味着团队需要去做这些事:


  • 构建自动化流水线系统,从构建测试到部署实现高度自动化;
  • 建立完善精确的监控体系,尽力让信息变透明,数据可度量;
  • 建立跨团队跨职能的沟通协作机制,形成团队的流程和文化;


DevOps工程师要做的事情


  • 帮助团队建立持续交付工作流程和工具;
  • 建立一套完善的监控报警系统和故障响应流程;
  • 构建适用于团队研发交付流程的基础技术设施;
  • 推动DevOps流程和文化在团队落地;
相关文章
|
Kubernetes Cloud Native 关系型数据库
使用Zadig从0到1搭建持续交付平台(上)
使用Zadig从0到1搭建持续交付平台
使用Zadig从0到1搭建持续交付平台(上)
|
2月前
|
运维 Devops jenkins
DevOps实践:持续集成与持续部署在现代软件开发中的作用
【10月更文挑战第42天】在快节奏的软件开发世界里,DevOps已经成为一种提升效率、确保质量和加速交付的重要方法。本文将深入探讨DevOps的核心组成部分—持续集成(CI)和持续部署(CD)—并展示它们如何通过自动化流程优化开发周期。我们将从基础概念讲起,逐步过渡到实际操作,最终通过一个简单代码示例来演示这一过程。文章旨在为读者提供清晰的指导,帮助他们理解和实现CI/CD流程,从而在软件开发领域取得竞争优势。
|
4月前
|
运维 Cloud Native Devops
云原生时代的DevOps实践:自动化、持续集成与持续部署
【9月更文挑战第3天】未来,随着人工智能、大数据等技术的不断融入,DevOps实践将更加智能化和自动化。我们将看到更多创新的技术和工具涌现出来,为软件开发和运维带来更多便利和效益。同时,跨团队协作和集成也将得到进一步加强,推动软件开发向更加高效、可靠和灵活的方向发展。
|
5月前
|
运维 监控 Devops
构建高效自动化运维体系:DevOps与容器化实践
【7月更文挑战第44天】在现代IT基础设施管理中,自动化运维已成为提升效率、降低成本、确保系统稳定性的关键。本文将探讨如何通过结合DevOps理念和容器化技术来构建一个高效的自动化运维体系。我们将分析这一体系对提高软件交付速度、优化资源利用率以及增强系统可靠性的积极影响,并提供一系列实施策略和最佳实践,帮助企业实现运维自动化转型。
|
5月前
|
持续交付 jenkins C#
“WPF与DevOps深度融合:从Jenkins配置到自动化部署全流程解析,助你实现持续集成与持续交付的无缝衔接”
【8月更文挑战第31天】本文详细介绍如何在Windows Presentation Foundation(WPF)项目中应用DevOps实践,实现自动化部署与持续集成。通过具体代码示例和步骤指导,介绍选择Jenkins作为CI/CD工具,结合Git进行源码管理,配置构建任务、触发器、环境、构建步骤、测试及部署等环节,显著提升开发效率和代码质量。
109 0
|
5月前
|
运维 Kubernetes Devops
DevOps实践之道:构建高效运维体系
在数字化转型的浪潮中,DevOps作为提升软件开发与运维效率的重要方法论,其核心在于打破开发与运维之间的壁垒,实现快速迭代和持续交付。本文深入探讨了DevOps的实践路径,从流程优化、工具选择到团队建设三个维度出发,结合具体案例分析DevOps实施过程中的挑战与解决策略,旨在为读者提供一套完整的DevOps落地框架,助力企业构建高效、灵活的运维体系。
152 0
|
8月前
|
运维 Kubernetes Devops
构建高效自动化运维体系:DevOps与容器化技术融合实践
【5月更文挑战第6天】随着企业IT架构的复杂化以及快速迭代的市场需求,传统的运维模式已难以满足高效率和高质量的交付标准。本文将探讨如何通过结合DevOps理念和容器化技术来构建一个高效的自动化运维体系,旨在实现持续集成、持续部署和自动化管理,提升系统的可靠性、可维护性和敏捷性。
|
8月前
|
运维 安全 Devops
DevSecOps:构建无缝安全的DevOps流程
在当今数字化时代,软件开发行业面临着越来越多的安全威胁。为了应对这些威胁,传统的软件开发模式已经无法满足需求。因此,DevSecOps应运而生,旨在将安全性融入到DevOps流程中。本文将介绍DevSecOps的概念和原则,并探讨如何实现无缝安全的DevOps流程。
|
监控 jenkins Java
持续集成/技术交付全流程流水线工具的设计与落地
持续集成/技术交付全流程流水线工具的设计与落地
181 0
|
运维 监控 安全
DevSecOps:将安全性纳入DevOps流程的实践
在当今快节奏的软件开发环境中,DevOps已成为一种广泛采用的开发方法论,旨在加速软件交付并提高团队合作。然而,随着安全威胁不断增加,仅仅追求速度和效率已不再足够。为了确保软件的安全性,将安全性纳入DevOps流程是至关重要的,这就是DevSecOps的核心理念。
304 0