敏捷开发代码管理规则:为什么要采用单一主干代码管理?如何做到单一主干代码管理?

2024-04-02 20:38

本文主要是介绍敏捷开发代码管理规则:为什么要采用单一主干代码管理?如何做到单一主干代码管理?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

http://blog.sina.com.cn/s/blog_74bd788f0101aohh.html

 

在敏捷开发中,单一主干代码管理经常被提及,那为什么要采用单一主干代码管理?单一主干代码管理带来哪些好处?如何做到持续发布新功能并定期稳定的可商用的版本?

         为什么采用单一主干代码管理?

在敏捷研发中的代码管理控制时,我们需要牢记两点[1]

首先,只有频繁提交代码,你才能享受版本控制带来的众多好处,比如及时回滚到最近的无错误版本。

其次,一旦将变更提交到版本控制中,那么团队的所有人都能看到这些变更。由于提交意味着公开,无论修改了什么,都要确保它不会破坏原有的系统,所有每一位开发人员必须谨慎的对待其提交可能带来的影响。

如果在版本控制系统中为新功能建立单独的分支,到某个时间点后,当这些修改内容的质量令人满意了,再将其合并到主干,这个类似“两阶段提交”。这种方式存在以下问题

1.       它违背了持续集成的宗旨,因为新建分支的做法推迟了新功能的整合,只有当该分支被合并时才可能发现集成问题。

2.       如果多个开发者同事分别创建多个分支,问题会成指数增加,而合并过程也会及其负责。

3.       它让重构代码变得非常困难,因为分支往往涉及多个文件,会让合并变得更加困难。

 

         单一主干代码管理带来的好处?

在代码管理时,如果单一主干代码管理,可以给开发团队带来如下的好处。

1.       确保所有的代码被持续集成,只有单一主干才能使得所有开发人员的代码被持续集成。

2.       确保开发人员及时获得他人代码,将开发人员间的影响及时暴露,减少由于沟通不及时带来的隐性问题。

3.       避免项目后期的“合并地狱”和“集成地狱”。

 

这样的做法可以让开发人员花更多的时间在架构设计和代码优化上,而不是从事代码合并工作。

 

 

         单一代码管理在已上线软件中存在的问题

那如何在单一主干代码做到持续集成新功能或优化代码,修复现网版本的bug及定期上线最新的商用版本?

         在实际开发工作中,单一主干的代码管理在项目新建立期间问题不太大,但是如果项目进入到维护期时,容易引入如下问题,

A. 紧急修复的即时性和版本开发的周期性的矛盾。

B. 版本连续开发中,开发和测试存在时间差,导致无法快速发布稳定的可商用的版本。

敏捷开发代码管理规则:为什么要采用单一主干代码管理?如何做到单一主干代码管理?
 

图1 研发过程中代码管理的状况

如图1所示,当我们在T0发布现网的版本后,开发人员每天checkin开发的最新代码,但每天开发的代码未必完全能够完成整个用户故事。如果在Tn开始下一版本的预发布,则测试团队在Tn时刻开始测试会遇到如下几种情况

1.       在Tn之前还存在一些没有解决的Bug

2.       在Tn之前还存在没有完全开发完成新的用户故事

3.       测试人员在Tn上的版本进行测试,会测试出一些新的bug

在这种情况下,开发人员会不断的checkin新代码,fix bug和完成新的用户故事,同时新checkin的代码可能产生新的bug,这样不断的循环,会导致生成一个稳定的版本变得十分困难而且非常耗时,一般会做法会采用如下方法,

1.       在Tn时刻确保所有的功能已经被开发完成,如果有没有开发完成的功能,所有开发人员等待剩余新功能的开发人员完成工作,完成后再开始测试工作。在测试中一般会采用以下两种方法,

a)         方法一,在Tn时刻为release版本分出分支,测试和研发基于生产的版本分支进行测试和代码开发。

b)         方法二,在Tn时刻不为release版本生产分支,所有开发人员停止新功能的研发工作,只完成测试人员测试出来的bug,此过程直到QA通过版本发布为止。

可以通过对以上两种方式分析,存在无法单一主干管理或者导致开发人员无法持续研发新的功能的问题,如果采用方法一还可能导致版本合并的问题。

 

如何能做到单一代码管理并不影响持续的新功能开发和软件发布?

         综上,在敏捷研发过程中,采用单一主干代码管理必须辅助一些规则,才能实现上面提到的矛盾。通过分析主要矛盾集中在持续的开发新功能和定期发布版本的矛盾,而且bug fix是属于小范围改动应该在于可控范围内,所制定规则如下,        

1.       新功能开发流程:增加一个打开状态的开关,此开关可以通过developing和developed两个标志来区分研发中,测试中和发布的状况,具体规则如下,

a)       研发状态:研发人员在开发新功能时,需要根据开发进度设置新功能块的状态,例:当新功能处于开发状态时,需要将此功能块设置成developing(开发中)状态。

b)       测试状态:当开发人员开发完毕,并完成本地测试没问题之后,将此功能块从developing状态改变成developed(开发完成)状态,交由测试人员对新功能进行测试。

c)       发布状态:当新功能测试完毕之后,由产品经理和功能负责人一起决定是否发布此功能,如果决定发布,将developed标识从功能模块中去掉,并通过团队评审,进入主干代码。


敏捷开发代码管理规则:为什么要采用单一主干代码管理?如何做到单一主干代码管理?
 

图2新功能研发代码管理规则

2.       定期发布稳定版本流程:

a)       开始测试预发布版本

1.       当从Tn时刻开始测试即将发布的版本时,通知所有研发人员,从这个时刻起停止所有新功能的状态变更,但是可以继续研发代码,并每天按照平时一样checkin 代码。

2.       所有的bug fix必须保证全部修复完成后才能checkin 代码(bug一般都能在1-2个工作日内完成修改)

b)       测试中:从Tn这个版本测试出来的问题,研发人员马上进行修复,并checkin到主干代码中,每天测试人员从库里取出编译出的最新版本进行测试(因为新模块的研发通过开关进行了控制,所以新模块的研发代码不会对软件质量造成影响),通过这个机制可以确保每天的代码是高于前一天的代码质量。

c)       完成测试,达到发布标志:当在T(n+m)时刻,如果软件质量达到发布要求,则在此版本号上打上发布版本的Tag,并通知所有开发人员可以重新开启修改developing和developed标志,使新的功能在产品中生效。

 

3.       紧急修复现网运营版本的Bug

a)       当系统上报bug后,首先需要对bug进行分析并进行归类,如果不会导致业务无法使用或者crash的bug,则作为一般的日常问题进入产品bug库,尽量不要对现网运营系统进行打补丁。

b)       如果发现了导致业务无法使用或者crash的bug,则找到现网的release版本,并在代码管理库此版本上拉出分支,并在此分支上进行bug fix,解决完成后,将相关代码立即合并会主干代码。

        通过以上规则处理,我们在实际敏捷研发中,在代码库规则中整体展现如下图所示

敏捷开发代码管理规则:为什么要采用单一主干代码管理?如何做到单一主干代码管理?
 

图3 建议的敏捷研发代码管理规则

相关其他工作

                  此处需要CM进行配合,才能很好的完成测试,研发和产品发布之间的配合,具体规则如下图所示:

敏捷开发代码管理规则:为什么要采用单一主干代码管理?如何做到单一主干代码管理?
 

图4 代码配置规则

           本文提到的代码状态规则需要根据不同的项目和编程语言设计方案,我们在Android和iOS系统研发下采用了if(){…} else{…}语句进行实现,在struts框架下研发采用返回不同的状态进行控制实现,其他项目的实际控制方法建议根据实现情况进行调整。

 


[1] Continuous Delivery –Reliable Software Releases Through Build,Test,and Deployment Automation [eng] Jez Humble, David Farley

 

这篇关于敏捷开发代码管理规则:为什么要采用单一主干代码管理?如何做到单一主干代码管理?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/870998

相关文章

uniapp接入微信小程序原生代码配置方案(优化版)

uniapp项目需要把微信小程序原生语法的功能代码嵌套过来,无需把原生代码转换为uniapp,可以配置拷贝的方式集成过来 1、拷贝代码包到src目录 2、vue.config.js中配置原生代码包直接拷贝到编译目录中 3、pages.json中配置分包目录,原生入口组件的路径 4、manifest.json中配置分包,使用原生组件 5、需要把原生代码包里的页面修改成组件的方

用Microsoft.Extensions.Hosting 管理WPF项目.

首先引入必要的包: <ItemGroup><PackageReference Include="CommunityToolkit.Mvvm" Version="8.2.2" /><PackageReference Include="Microsoft.Extensions.Hosting" Version="8.0.0" /><PackageReference Include="Serilog

公共筛选组件(二次封装antd)支持代码提示

如果项目是基于antd组件库为基础搭建,可使用此公共筛选组件 使用到的库 npm i antdnpm i lodash-esnpm i @types/lodash-es -D /components/CommonSearch index.tsx import React from 'react';import { Button, Card, Form } from 'antd'

17.用300行代码手写初体验Spring V1.0版本

1.1.课程目标 1、了解看源码最有效的方式,先猜测后验证,不要一开始就去调试代码。 2、浓缩就是精华,用 300行最简洁的代码 提炼Spring的基本设计思想。 3、掌握Spring框架的基本脉络。 1.2.内容定位 1、 具有1年以上的SpringMVC使用经验。 2、 希望深入了解Spring源码的人群,对 Spring有一个整体的宏观感受。 3、 全程手写实现SpringM

关于如何更好管理好数据库的一点思考

本文尝试从数据库设计理论、ER图简介、性能优化、避免过度设计及权限管理方面进行思考阐述。 一、数据库范式 以下通过详细的示例说明数据库范式的概念,将逐步规范化一个例子,逐级说明每个范式的要求和变换过程。 示例:学生课程登记系统 初始表格如下: 学生ID学生姓名课程ID课程名称教师教师办公室1张三101数学王老师101室2李四102英语李老师102室3王五101数学王老师101室4赵六103物理陈

代码随想录算法训练营:12/60

非科班学习算法day12 | LeetCode150:逆波兰表达式 ,Leetcode239: 滑动窗口最大值  目录 介绍 一、基础概念补充: 1.c++字符串转为数字 1. std::stoi, std::stol, std::stoll, std::stoul, std::stoull(最常用) 2. std::stringstream 3. std::atoi, std

Eclipse+ADT与Android Studio开发的区别

下文的EA指Eclipse+ADT,AS就是指Android Studio。 就编写界面布局来说AS可以边开发边预览(所见即所得,以及多个屏幕预览),这个优势比较大。AS运行时占的内存比EA的要小。AS创建项目时要创建gradle项目框架,so,创建项目时AS比较慢。android studio基于gradle构建项目,你无法同时集中管理和维护多个项目的源码,而eclipse ADT可以同时打开

记录AS混淆代码模板

开启混淆得先在build.gradle文件中把 minifyEnabled false改成true,以及shrinkResources true//去除无用的resource文件 这些是写在proguard-rules.pro文件内的 指定代码的压缩级别 -optimizationpasses 5 包明不混合大小写 -dontusemixedcaseclassnames 不去忽略非公共

springboot家政服务管理平台 LW +PPT+源码+讲解

3系统的可行性研究及需求分析 3.1可行性研究 3.1.1技术可行性分析 经过大学四年的学习,已经掌握了JAVA、Mysql数据库等方面的编程技巧和方法,对于这些技术该有的软硬件配置也是齐全的,能够满足开发的需要。 本家政服务管理平台采用的是Mysql作为数据库,可以绝对地保证用户数据的安全;可以与Mysql数据库进行无缝连接。 所以,家政服务管理平台在技术上是可以实施的。 3.1

Python应用开发——30天学习Streamlit Python包进行APP的构建(9)

st.area_chart 显示区域图。 这是围绕 st.altair_chart 的语法糖。主要区别在于该命令使用数据自身的列和指数来计算图表的 Altair 规格。因此,在许多 "只需绘制此图 "的情况下,该命令更易于使用,但可定制性较差。 如果 st.area_chart 无法正确猜测数据规格,请尝试使用 st.altair_chart 指定所需的图表。 Function signa