为什么使用Git

“svn用了这么多年都好好的,为啥折腾搞Git?”
“Git一点都不好用,提交个代码都提交不上去!”
“Git这么复杂,命令多到记不住,而且完全用不到。哪有svn简单好用?”
 
推销任何一种新事物,无论新事物本身是否先进,最能打动客户的一点就是,能否解决客户的痛点,能否给客户带来价值。
拿软件开发过程来说,项目团队关注项目版本的可控性,包括对多个版本的开发、构建、测试、发布、特性等管理;关注持续集成的效率等;开发团队关注代码管理、回溯、合并的可控性;关注开发协同等;
在svn(目前在用的版本管理工具)的上述痛点,Git都能很大的解决或改善。推广Git,背后的目的就是提高项目产品的质量和团队开发的效率。当然,任何收益都有代价,在支持如此多的特性的同时,Git的使用复杂度也势必增加。
本文侧重讨论Git在团队的推广,所以首先回答一下,相较于svn,Git给开发中个人和开发团队带来的价值:
  • 对于开发者,可以随时提交修改到本地仓库,方便代码修改查看,回滚,终结svn时代开发阶段无代码管理工具、代码管理混乱的窘境,提高个人代码管理效率。
  • 如果一个功能需要尝试多种方案进行对比,开发者可以通过本地分支对多个方案代码进行修改、对比、查看等管理,终结svn时代手动备份代码的远古习惯,提高个人代码管理效率。
  • 如果一个功能需要多人协同开发,可以通过Git分支协同开发,驱散自己搭svn服务器、建svn仓库、代码手动同步的苦闷,提升团队协同开发效率。
  • 如果这些都没有打动你,那还有最后一点:全世界都在用Git,作为基本技能的Git你都不会的话,以后找工作都困难哦。
 

团队级Git分支模型

Git本身并没有推荐的最佳实践,但有很多非官方的最佳实践总结,比如这篇《一个成功的Git分支模型》,这个分支模型贯穿整个产品的生命周期,为整个产品项目服务。这个模型过于复杂,特别是对于特性团队级的Git来说,有点重了。
团队的Git分支策略由使用场景、任务特点、开发周期等决定,在团队2年多的Git使用实践中,主要用到了如下三种分支模型:
  • remote/master
  • remote/master, remote/dev
  • remote/master,  local dev
 
分支详情展示:
alex@alex-desktop:~/healthcheck$ git br -a
* master
remotes/origin/master

这个分支模型只有master分支。适用于在新团队中起步推广Git,避免使用复杂的分支模型,引起程序员心理不适。而且对于不需要协同开发的任务,这个分支模型也够用了。

alex@alex-desktop:~/sc/robot_framework$ git br -a
develop
* master
remotes/origin/develop
remotes/origin/master

这个分支模型有master和dev分支,master分支是稳定版本分支,用于每日自动化测试的持续集成,要保证功能稳定。dev分支是开发分支,用于新特性开发和协同开发需要。

 
alex@alex-desktop:~/sc/ci$ git br -a
* alex_dev
master
remotes/origin/master

这个分支模型除了一个master分支外,还有一个未推送的本地dev分支。这种分支模型适用于如下场景:想验证对比多个实现方案,对已有实现采用多种策略进行重构尝试;只想从主分支同步某些合入,避免不相关的同步破坏自己正在开发的功能。

 

团队级Git工作流程

Git之所以强大,主要来自其复杂的分支模型和分布式策略,这也是其复杂的原因。
Git命令是操作的是Git对象和对象间的关系。所以要掌握Git,理解Git的工作机制,首先要理解Git中的基本对象,比如远程仓库、本地仓库、远程分支、本地分支,暂存区(stage)、工作区(workspace),以及数据是如何在这些对象中流动的。在这基础上,才有可能真正掌握Git。
上图是前面介绍的几种分支模型下的Git工作流及相关命令的总结梳理。
详细的命令讲解这里不再赘述,请读者咨询Google。这里只对几个易混淆的操作命令的区别总结如下:
  • fetch只更新local repo,不修改local branch;
  • pull更新local branch,pull等价于fetch+merge,pull -r等价于fetch+rebase;
  • merge、rebase同时更新local branch、stage和workspace,只是合并策略不同;
  • reset更新local branch和stage,不更新workspace;
  • checkout更新stage和workspace,不修改local branch
 

Git推广注意事项

  • Git推广中的最大的问题往往是最简单的问题,比如软件安装、兼容。所以最好能提供工具来统一环境,包括操作系统、基础软件、Git版本、Git配置等;
  • 提前准备好各系统的安装包、安装说明,方便所有人访问查阅;
  • 制定Git使用规范,通过工具,在环境配置、分支管理、提交日志、提交策略做好统一约束;
  • 采用适合任务特点和团队的Git模型,不要盲目仿照。
 

-EOF-

 
 
 
 

团队Git工作流总结的更多相关文章

  1. 开发环境之git:团队协作git工作流与常用命令

    此篇文章只是一篇傻瓜式的,记录工作中比较规范且常见的一个git工作流需要用到的命令,让你可以快速的开始工作.而不是一些长篇大论的理论知识,如果你有用过sourcetree或者其它图形化工具,结合你正在 ...

  2. Git工作流总结

    引用自:https://github.com/xirong/my-git/blob/master/git-workflow-tutorial.md 说明: 个人在学习Git工作流的过程中,从原有的 S ...

  3. 深入理解学习Git工作流

    http://blog.csdn.net/hongchangfirst/article/list/3 //可以看看 http://blog.csdn.net/hongchangfirst/articl ...

  4. [转]深入理解学习GIT工作流

    深入理解学习Git工作流 字数13437 阅读2761 评论3 喜欢70 个人在学习git工作流的过程中,从原有的 SVN 模式很难完全理解git的协作模式,直到有一天我看到了下面的文章,好多遗留在心 ...

  5. 深入理解学习Git工作流(转)

    个人在学习git工作流的过程中,从原有的 SVN 模式很难完全理解git的协作模式,直到有一天我看到了下面的文章,好多遗留在心中的困惑迎刃而解,于是我将这部分资料进行整理放到了github上,欢迎st ...

  6. Git工作流:中心工作流(翻译)

    使用Git作为版本控制器,有众多可能的工作流(Workflow),这使得我们这些新鸟不知道在实际工作中不知道该选择哪种工作流.这里我们对最常见的Git工作流做一个对比,为企业团队提供一个参考. 正如你 ...

  7. git 工作流介绍

    GIT Git工作流你可以理解为工作中团队成员遵守的一种代码管理方案,在Git中有以下几种工作流方案作为方案指导: 集中式工作流 功能开发工作流 Gitflow工作流 Forking工作流 下面针对性 ...

  8. 【学习总结】Git学习-GIT工作流-千峰教育(来自B站)

    Git工作流指南 - av32575602 文档资料 目录: 1-什么是版本控制系统 2-工作流简介 3-集中式工作流 4-功能分支工作流 5-GitFlow工作流 小记: 初看差点放弃了,不过后面还 ...

  9. 四种常见 Git 工作流比较

    BY 童仲毅(geeeeeeeeek@github) 这是一篇在原文(BY atlassian)基础上演绎的译文.除非另行注明,页面上所有内容采用知识共享-署名(CC BY 2.5 AU)协议共享. ...

随机推荐

  1. 图解JVM的Class文件格式(详细版)

          了解JAVA的Class文件结构有助于掌握JAVA语言的底层运行机制,我在学习的过程中会不断的与ELF文件格式作对比(当然他们的复杂程度.格式相去甚远,比如可执行ELF的符号表解析在静态链 ...

  2. NAT穿越

    1.NAT类型 目前主要的NAT类型有如下几种: 1)Full-cone NAT, also known as one-to-one NAT 一旦一个内网地址 (iAddr:iPort) 被映射到一个 ...

  3. Solr学习总结(二)Solr的安装与配置

    接着前一篇,这里总结下Solr的安装与配置 1.准备 1.安装Java8 和 Tomcat9 ,java和tomcat 的安装这里不再重复.需要注意的是这两个的版本兼容问题.貌似java8 不支持,t ...

  4. SVN如何查看修改的文件记录] 来源:Linux社区 作者:frogoscar

    SVN如何查看修改的文件记录 [日期:2014-11-20] 来源:Linux社区  作者:frogoscar [字体:大 中 小]     主要是有四个命令,svn log用来展示svn 的版本作者 ...

  5. sql中的!=判断的注意事项

    sql查询中where过滤条件为某字段 colName='xx'时一般不会出什么问题, 但如果想达到不为xx的时候就要注意了,用colName!= 'xx'可能就有问题了,因为该字段可能为空,为nul ...

  6. print、sp_helptext的限制与扩展

    在SQL中,使用动态SQL是很常见的.有些复杂的计算,或是存储过程,代码很长,中间可能有多次执行SQL语句.而调试拼串的SQL语句却是件痛苦的事,很难看出来运行的语句是什么.所以我会经常使用print ...

  7. cf723b Text Document Analysis

    Modern text editors usually show some information regarding the document being edited. For example, ...

  8. R语言——七月

    这两个月没有写什么代码.也没做什么大项目,基本就是对以前写的那个用ggplot2可视化数据的项目做一些增增补补,大部分技术难关都在ggplot2和R语言EXCEL处理这里解决并总结了.然后业余帮人修改 ...

  9. Linux mkdir 创建文件夹命令

    介绍: 该命令创建指定的目录名,要求创建目录的用户在当前目录中具有写权限,并且指定的目录名不能是当前目录中已有的目录 语法: mkdir [-m] [-p] 目录名 选项介绍: -m: 对新建目录设置 ...

  10. url和urn和uri

    1.需求 理清三者的关系 2.例子 3.说明 url是资源的位置(包含scheme),urn表示资源的名字.url是唯一的.urn不是. 他们2个都是uri的子集 参考资料:https://danie ...