一旦涉及到版本控制系统,Git实际上代表敏捷开发的水平。Git作为一款强大的开源系统,有较强的灵活性,可以按需匹配任何开发团队的工作流程。而这种分布式相比较集中式来说,可以赋予系统更好的性能特征,且允许开发人员在本地自由实验,在他们修改到自己认为没有问题时再发布到团队。
除了灵活性和分布式等优点外,Git的主要职能是支持和强化敏捷开发。将Git视为敏捷开发的一部分,与单片发布和集中版本控制系统相比,所有变更可以更快部署。

专家提示:
Git是分布式版本控制系统(DVCS)。与CVS或Subversion (SVN)等工具不同,Git允许开发人员在团队资源库中创建个人独有的分支,并与主代码库并行存储。这些自创副本被称为fork。fork上的工作完成后,开发人员可以很轻松地将更改上传至主代码库。

方法一:将开发任务视为Git的分支

在产品功能细化并添加至产品路线图,开发团队做好开工准备后,Git开始发挥作用。但在正式开发之前,团队需要有一个敏捷功能开发速成课:产品、设计、质保(QA)、研发要开一个功能启动会就具体的功能、项目范围以及为了确保完成这些功能该被分解成什么样的任务等方面达成共识。在这些被称为用户故事的任务拆解完成之后,任务会分配给各个开发人员。Git也是在这个时候参与到我们的敏捷开发流程中。

在Worktile,我们会为每个独立的任务创建一个新的分支,无论是新的功能,BUG修复还是对现有代码的调整,每次代码的更改都会创建新的分支作为开发分支,等我们把功能完全做完之后,会提交Pull Request 到develop分支或者其他我们稳定的分支中,有管理员或者其他有合并权限的成员进行代码 Review,之后合并代码。

分支的应用使任务变得直观易懂,同时允许团队在一个中央代码库内轻松协作。开发人员一旦创建了分支,就意味着他们实际上拥有独立于中央代码库之外的个人代码库。

对敏捷团队而言,将功能拆分为用户故事后创建相应的分支,意味着开发团队的成员可以单独处理各自的任务,基于相同的代码库在不同的仓储下工作。开发工作量并未因此增加,因为开发人员能够更专注在与主仓储分开的小块任务,这样也避免因为存在过多依赖关系而减缓开发进程。

专家提示:
除了设置任务分支之外,还可以设置其他类型的Git分支,且它们之间可以兼容并存。例如,我们可以为单个版本的发布设置不同的分支,这样可以让开发人员为特定版本进一步制定稳定和强化的工作计划,而同时也不会影响到其他开发人员开发未来的版本。

创建单个版本发布的分支之后,需要定期将其融合到主分支任务中,确保所涉及的功能都能兼容到未来的版本中并发挥作用。为了最大限度地减少积压,所创建的单个版本发布的分支最好尽可能接近计划发布日期。

方法二:充分利用多分支可单独测试的优势

分支一旦被认为已经完成并可以进行代码review后,Git就开始在敏捷开发流程中扮演另外一个关键角色:测试。成功的敏捷团队会进行代码review并进行自动化测试(持续集成)。为了更好地完成代码review和测试工作,开发人员可以直接通知团队其他成员该分支已经完成可以review,然后提交Pull Request。简单来讲,Pull Request就是请求其他开发人员将你已经做好可以进行测试的分支合并到主分支上。
如果工具使用得当,持续集成服务器就可以在合并之前创建并检测你提交的Pull Request。这样做能确保合并分支不会出现问题。通常情况下,还能让我们更轻松地重新定位Bug修复和冲突,因为在各分支之间存在分歧时,Git能够区分各分支与主代码库之间的差异。

专家提示:
一个长期运行且未合并到主分支的分支,可能会影响团队的敏捷性和迭代能力。如果存在一个长期运行的分支,就意味着实际上存在两个不同版本的代码库,而这将直接带来更多的bug修复工作和冲突。最好的解决方式是设定短期的分支,可以通过将用户故事拆分为较小的任务、更为细致的sprint规划以及尽早合并代码作为隐性特征(dark features)等这些方式来实现。

方法三:Git确保敏捷开发的透明度和质量

Git/敏捷故事通常与效率、测试、自动化和整体敏捷性有关。将分支合并到主分支后,敏捷的工作流程就完成了。同样,通过提交Pull Request将代码合并后,意味着在代码完成的同时,所有文档中的工作也已经完成,团队其他成员已经停止代码活动,且已经可以进行发布。这使得敏捷团队可以快速而自信地进行频繁的发布:这也是成功敏捷团队的一个标志。

专家提示:

定期发布是敏捷开发的关键。要让Git适应敏捷工作流程,就要确保主分支一直是健康畅通的。这意味着,如果某个功能尚未做好,就可以等到下次再发版。如果团队想尝试较短的发版周期,也是可以的。

 

文章来源:Worktile敏捷博客

欢迎访问交流更多关于技术及协作的问题。

文章转载请注明出处。

如何让Git适应敏捷开发流程?的更多相关文章

  1. 小谈Scrum敏捷开发流程

    一晃眼,有两年没有写博客了,回顾前两年,各种奔波,各种忙碌,也有不少的收获.从今天开始,我要把这些收获都分享在这里. 其实这两年,对我影响最大的是开发流程.总所周知,一个好的开发流程,对于项目的进行, ...

  2. git 一般的开发流程中的代码管理

    一般的开发流程中的代码管理 1. 从版本库中下载代码 git clone ssh://wenbin@192.168.1.3:29418/mustang-web 2. 针对某个feature(比如ins ...

  3. 敏捷开发 and 敏捷测试

    名词解释 agile: 敏捷的:灵活:敏捷开发. scrum: 扭打,混打:并列争球:参加并列争球. sprint:  冲刺,全速跑. backlog: 积压的工作:积压待办的事务. retrospe ...

  4. IPD体系向敏捷开发模式转型实施成功的四个关键因素

    文/杨学明  集成产品开发(IPD).集成能力成熟度模型(CMMI).敏捷开发(Agile Development)是当前国内外企业产品研发管理的最常用的3种模式.随着创新环境的快速发展,许多企业都会 ...

  5. 敏捷开发——User Story

    敏捷开发流程: 1.我们首先需要确定一个Product Backlog(按优先顺序排列的一个产品需求列表),这个是由Product Owner 负责的: 2.Scrum Team根据Product B ...

  6. 杨学明老师推出全新课程--《敏捷开发&IPD和敏捷开发结合的实践》

    课时:13小时(2天) 敏捷开发&IPD和敏捷开发结合的实践 讲  师:杨学明 [课程背景] 集成产品开发(IPD).集成能力成熟度模型(CMMI).敏捷开发(Agile Developmen ...

  7. 浅谈Scrum敏捷开发:4个输入/输出、3个关键物、3个会议

    文章对Scrum敏捷开发流程进行系统的分析,希望借此文能够加深你对敏捷开发的认知,更好的展开产品工作. Scrum敏捷开发,是一种敏捷开发框架,是一个增量的.迭代的开发过程,具备可视.可集成和可运行使 ...

  8. 20175316 盛茂淞 2018-2019-2 《Java程序设计》实验三《敏捷开发与XP实践》 实验报告

    实验内容与要求 1.XP基础 极限编程(Extreme Programming,XP)是一种全新而快捷的软件开发方法.XP团队使用现场客户.特殊计划方法和持续测试来提供快速的反馈和全面的交流: XP是 ...

  9. 环信联合创始人: Saas敏捷开发实践!

    马晓宇 --环信联合创始人/执行总裁 我们是一个做云服务的创业公司,所以我就云服务创业公司的角度,来谈谈我们是怎么去实践敏捷开发的.确切地说,就是讲讲我们这几年的这些教训... 1-创业公司敏捷开发流 ...

随机推荐

  1. EF 6.0 Code First 迁移MySql数据库

    一.准备工作     使用NUGET安装Entity Framework 6,下载MySql Connector/Net 6.9.5   二.创建实体     我们在下面创建了两个类(博客和文章),并 ...

  2. 使用fastjson读取超巨json文件引起的GC问题

    项目中需要将巨量数据生成的json文件解析,并写入数据库,使用了 alibaba 的 fastjson,在实践过程中遇到了 GC 问题,记录如下: 数据大约为70万条,文件大小在3~4G左右,使用 f ...

  3. SQL Server Alwayson架构下 服务器 各虚拟IP漂移监控告警的功能实现 -2(虚拟IP视角)

    1.需求描述 我们知道Windows Cluster 都是多节点的,当虚拟IP漂移的时候,一般都是从一个节点漂移到另外一个节点.如果可以及时捕捉到旧节点信息是什么.新节点信息是什么对我们提供高可用的数 ...

  4. 用nodejs调用webservice

    用nodejs调用webservice,是用soap包实现的. 步骤如下: 第一步:安装soap包 npm  install soap 第二部:调用webservice var soap = requ ...

  5. 对SpringMVC架构进行工程拆分遇到的问题总结

    经过一个月的开发,一个单一的SpringMVC教育类创业项目正式上线,随着时间的推移,业务流量逐渐增大,最近对这个单一的工程从零进行SOA分布式改造,改造包括dubbo改造,集成化部署.高可用集群,负 ...

  6. 【练习题】proj2 字符串压缩

    输入一个字符串,输出简单的压缩 1)单字符串压缩 : 输入:ABBBCCD , 输出AB3C2D 2)多字符串压缩 输入:AABCABCD,输出A(ABC)2D 1)压缩单个字符 #include & ...

  7. 修改linux(kali)和windows双系统下默认启动系统和启动延时

    我的公众号,正在建设中,欢迎关注: windows和kali双系统安装完成后kali是默认的启动系统,现将windows设置为默认启动系统并更改选择系统等待时间 1.开机时当运行到系统选择菜单时记下w ...

  8. Mac和Windows以及Linux上WingIDE Pro激活

    写这篇文章的原因,主要是网上的很多激活方式都不适用最新版的软件.要么要你付费下载别人破解好的内容,要么各种文章你抄我,我抄你,根本没有自己实践过. 本篇文章合适Mac.Windows.Linux平台, ...

  9. 基于百度云的OCR识别(Python)

    2019年7月3日早上,在百度AI开发者大会上,一个来自山西的青年,将一瓶矿泉水浇在了同样来自山西的李彦宏身上. 可以回顾一下 https://b23.tv/av57665929/p1 ,着实让人一惊 ...

  10. JAVA Stirng.format 使用理解

    JAVA Stirng.format 使用理解前言:项目中需要对一些字符串处理发现format方法的神奇之处一.api才是王道第一种二参使用①public static String format(S ...