关键词:
目录
- 前言
- 仓库(Repository)
- 源仓库
- 开发者仓库
- 分支(Branch)
- 永久性分支
- 暂时性分支
- 工作流(workflow)
- 总结
- 参考资料
前言
(本文假设各位已经对基本git的基本概念、操作有一定的理解,如无相关git知识,可以参考Pro Git这本书进行相关的学习和练习)
很多项目开发都会采用git这一优秀的分布式版本管理工具进行项目版本管理,使用github开源平台作为代码仓库托管平台。由于git的使用非常灵活,在实践当中衍生了很多种不同的工作流程,不同的项目、不同的团队会有不同的协作方式。
本文将介绍一种前人已经在各种大小项目中经过千锤百炼总结出来的一种比较成功的git工作流,这种工作流已经被成功用于许多团队开发当中。掌握git,掌握这种工作流,对大家以后的学习、开发工作大有好处。
先上一张图吓大家一下:
上面一张图展示了一种使用git进行项目协同开发的模式,接下来会进行详细介绍。
仓库(Repository)
在项目的开始到结束,我们会有两种仓库。一种是源仓库(origin),一种是开发者仓库。上图中的每个矩形都表示一个仓库,正中间的是我们的源仓库,而其他围绕着源仓库的则是开发者仓库。
源仓库
在项目的开始,项目的发起者构建起一个项目的最原始的仓库,我们把它称为origin
,例如我们的PingHackers网站,origin
就是这个PingHackers/blog了。源仓库的有两个作用:
- 汇总参与该项目的各个开发者的代码
- 存放趋于稳定和可发布的代码
源仓库应该是受保护的,开发者不应该直接对其进行开发工作。只有项目管理者(通常是项目发起人)能对其进行较高权限的操作。
开发者仓库
上面说过,任何开发者都不会对源仓库进行直接的操作,源仓库建立以后,每个开发者需要做的事情就是把源仓库的“复制”一份,作为自己日常开发的仓库。这个复制,也就是github上面的fork
。
每个开发者所fork的仓库是完全独立的,互不干扰,甚至与源仓库都无关。每个开发者仓库相当于一个源仓库实体的影像,开发者在这个影像中进行编码,提交到自己的仓库中,这样就可以轻易地实现团队成员之间的并行开发工作。而开发工作完成以后,开发者可以向源仓库发送pull request
,请求管理员把自己的代码合并到源仓库中,这样就实现了分布式开发工作,和最后的集中式的管理。
分支(Branch)
分支是git中非常重要的一个概念,也是git这一个工具中的大杀器,必杀技。在其他集中式版本管理工具(SVN/CVS)把分支定位为高级技巧,而在git中,分支操作则是每个开发人员日常工作流。利用git的分支,可以非常方便地进行开发和测试,如果使用git没有让你感到轻松和愉悦,那是因为你还没有学会使用分支。不把分支用出一点翔来,不要轻易跟别人说你用过git。
在文章开头的那张图中,每一个矩形内部纷繁的枝蔓便是git的分支模型。可以看出,每个开发者的仓库都有自己的分支路线,而这些分支路线会通过代码汇总映射到源仓库中去。
我们为git定下一种分支模型,在这种模型中,分支有两类,五种
- 永久性分支
master branch
:主分支develop branch
:开发分支
- 临时性分支
feature branch
:功能分支release branch
:预发布分支hotfix branch
:bug修复分支
永久性分支
永久性分支是寿命无限的分支,存在于整个项目的开始、开发、迭代、终止过程中。永久性分支只有两个master
和develop
。
master:主分支从项目一开始便存在,它用于存放经过测试,已经完全稳定代码;在项目开发以后的任何时刻当中,master
存放的代码应该是可作为产品供用户使用的代码。所以,应该随时保持master
仓库代码的清洁和稳定,确保入库之前是通过完全测试和代码reivew的。master
分支是所有分支中最不活跃的,大概每个月或每两个月更新一次,每一次master
更新的时候都应该用git打上tag
,说明你的产品有新版本发布了。
develop:开发分支,一开始从master分支中分离出来,用于开发者存放基本稳定代码。之前说过,每个开发者的仓库相当于源仓库的一个镜像,每个开发者自己的仓库上也有master
和develop
。开发者把功能做好以后,是存放到自己的develop
中,当测试完以后,可以向管理者发起一个pull request
,请求把自己仓库的develop
分支合并到源仓库的develop
中。
所有开发者开发好的功能会在源仓库的develop
分支中进行汇总,当develop
中的代码经过不断的测试,已经逐渐趋于稳定了,接近产品目标了。这时候,我们就可以把develop
分支合并到master
分支中,发布一个新版本。所以,一个产品不断完善和发布过程就正如下图:
注意,任何人不应该向master
直接进行无意义的合并、提交操作。正常情况下,master
只应该接受develop
的合并,也就是说,master
所有代码更新应该源于合并develop
的代码。
暂时性分支
暂时性分支和永久性分支不同,暂时性分支在开发过程中是一定会被删除的。所有暂时性分支,一般源于develop
,最终也一定会回归合并到develop
。
feature:功能性分支,是用于开发项目的功能的分支,是开发者主要战斗阵地。开发者在本地仓库从develop
分支分出功能分支,在该分支上进行功能的开发,开发完成以后再合并到develop
分支上,这时候功能性分支已经完成任务,可以删除。功能性分支的命名一般为feature-*
,*为需要开发的功能的名称。
举一个例子,假设我是一名PingHackers网站的开发者,已经把源仓库fork了,并且clone到了本地。现在要开发PingHackers网站的“讨论”功能。我在本地仓库中可以这样做:
step 1: 切换到develop
分支
>>> git checkout develop
step 2: 分出一个功能性分支
>>> git checkout -b feature-discuss
step 3: 在功能性分支上进行开发工作,多次commit,测试以后...
step 4: 把做好的功能合并到develop
中
>>> git checkout develop
# 回到develop分支
>>> git merge --no-ff feature-discuss
# 把做好的功能合并到develop中
>>> git branch -d feature-discuss
# 删除功能性分支
>>> git push origin develop
# 把develop提交到自己的远程仓库中
这样,就完成一次功能的开发和提交。
release:预发布分支,当产品即将发布的时候,要进行最后的调整和测试,这时候就可以分出一个预发布分支,进行最后的bug fix。测试完全以后,发布新版本,就可以把预发布分支删除。预发布分支一般命名为release-*
。
hotfix:修复bug分支,当产品已经发布了,突然出现了重大的bug。这时候就要新建一个hotfix
分支,继续紧急的bug修复工作,当bug修复完以后,把该分支合并到master
和develop
以后,就可以把该分支删除。修复bug分支命名一般为hotfix-*
release
和hotfix
分支离我们还比较遥远。。就不详述,有兴趣的同学可以参考本文最后的参考资料进行学习。
工作流(Workflow)
啰嗦讲了这么多,概念永远是抽象的。对于新手来说,都喜欢一步一步的步骤傻瓜教程,接下来,我们就一步一步来操作上面所说的工作流程,大家感受一下:
Step 1:源仓库的构建
这一步通常由项目发起人来操作,我们这里把管理员设为PingHackers,假设PingHackers已经为我们建立起了一个源仓库PingHackers/git-demo,并且已经初始化了两个永久性分支master
和develop
,如图:
Step 2:开发者fork源仓库
源仓库建立以后,每个开发就可以去复制一份源仓库到自己的github账号中,然后作为自己开发所用的仓库。假设我是一个项目中的开发者,我就到PingHackers/git-demo项目主页上去fork
:
fork
完以后,我就可以在我自己的仓库列表中看到一个和源仓库一模一样的复制品。这时就应该感叹,你以后要和它相依为命了:
Step 3:把自己开发者仓库clone到本地
这一步应该不用教,git clone
Step 4:构建功能分支进行开发
进入仓库中,按照前面说所的构建功能分支的步骤,构建功能分支进行开发、合并,假设我现在要开发一个“讨论”功能:
>>> git checkout develop
# 切换到`develop`分支
>>> git checkout -b feature-discuss
# 分出一个功能性分支
>> touch discuss.js
# 假装discuss.js就是我们要开发的功能
>> git add .
>> git commit -m ‘finish discuss feature‘
# 提交更改
>>> git checkout develop
# 回到develop分支
>>> git merge --no-ff feature-discuss
# 把做好的功能合并到develop中
>>> git branch -d feature-discuss
# 删除功能性分支
>>> git push origin develop
# 把develop提交到自己的远程仓库中
这时候,你上自己github的项目主页中develop
分支中看看,已经有discuss.js
这个文件了:
Step 5:向管理员提交pull request
假设我完成了“讨论”功能(当然,你还可能对自己的develop
进行了多次合并,完成了多个功能),经过测试以后,觉得没问题,就可以请求管理员把自己仓库的develop分支合并到源仓库的develop分支中,这就是传说中的pull request
。
点击上图的绿色按钮,开发者就可以就可以静静地等待管理员对你的提交的评审了。
Step 6 管理员测试、合并
接下来就是管理员的操作了,作为管理员的PingHackers登陆github,便看到了我对源仓库发起的pull request
。
这时候PingHackers需要做的事情就是:
- 对我的代码进行review。github提供非常强大的代码review功能:
-
在他的本地测试新建一个测试分支,测试我的代码:
>> git checkout develop # 进入他本地的develop分支 >> git checkout -b livoras-develop # 从develop分支中分出一个叫livoras-develop的测试分支测试我的代码 >> git pull https://github.com/livoras/git-demo.git develop # 把我的代码pull到测试分支中,进行测试
-
判断是否同意合并到源仓库的
develop
中,如果经过测试没问题,可以把我的代码合并到源仓库的develop
中:>> git checkout develop >> git merge --no-ff livoras-develop >> git push origin develop
注意,PingHakers一直在操作的仓库是源仓库。所以我们经过上面一系列操作以后,就可以在源仓库主页中看到:
经过辗转曲折的路程,我们的discuss.js
终于从我的开发仓库的功能分支到达了源仓库的develop
分支中。以上,就是一个git & github协同工作流的基本步骤。
总结
git这一个工具博大精深,很难想象竟然有使用如此恶心而又如此灵活和优雅的工具存在;此又为一神器,大家还是多动手,多查资料,让git成为自己的一项基本技能,帮助自己处理各种项目团队协同工作的问题,成为一个高效的开发者、优秀的项目的管理者。送大家一张神图,好好领悟:
最后给出一些参考资料,供参考学习。
出处:https://segmentfault.com/a/1190000002413519#articleHeader2
http://www.ruanyifeng.com/blog/2012/07/git.html
使用github进行协同项目开发和开源项目贡献
本教程致力于摆脱git命令行快速的学习使用GitHub。此次是GitHub课程的第三次课程,也是最后一次课程。推荐进行按照次序查看本次教程。上篇文章:程序员,一起玩转GitHub版本控制,超简单入门教程干货2本教程由今日头条-全栈... 查看详情
ios协同开发-ios代码版本控制-github代码托-关东升-专题视频课程
...课程介绍 介绍了如何使用Git进行代码版本控制,其中包括Git服务器的搭建、Git常用命令和协同开发,还介绍了如何配置和使用Git工具。GitHub是一个优秀的Git开发社区,使用GitHub代码托管服务是... 查看详情
git学习笔记远程库(github)协同开发,fork和忽略特殊文件
...本地的git仓库!他的工作方式和我们本地的一样,但是要使用他就需要先建立连接! 远程库有两种,一个是自己搭建的git服务器;另一种就是使用GitHub,这个网站就是提供Git仓库托管服务的,所以,只要注册一个GitHub账号... 查看详情
android协同开发篇(git)androidstudio中使用git进行协同开发
...udio软件已经集成了Git的功能,可以借助开发工具直接使用,不需要敲命令,进行协同开发二、在Androidstudio初始化界面中使用git导入远程仓库项目三、在Androidstudio中使用git导入远程仓库项目四、任意选择远程分支... 查看详情
github协同开发
ithub开发流程Github的流程。也就是:开发者各自fork项目的repo到自己Github账户下每次开发同步到项目的repo然后再进行开发push自己的开发分支到自己Github账户下面的fork的项目repo发送pullrequest给项目管理员等待review或者merge分支规划... 查看详情
git协同开发流程(代码片段)
...库Step3:把自己开发者仓库clone到本地Step4:构建功能分支进行开发Step5:向管理员提交pullrequestStep6:管理员测试、合并总结前言仓库(Repository)源仓库开发者仓库分支(Branch)永久 查看详情
git操作命令和github使用(代码片段)
git代码协同管理工具代码管理工具作用*防止代码丢失,做备份*代码版本的管理,可以进行多个节点的备份,在多个版本之间跳跃*可以方便的将代码在多人之间进行共享传输*多人开发时有各种模式可以方便代码管理什么是gitgit... 查看详情
git+github协作开发流程
...开发步骤如下:1.建立协作开发关系1.项目创建者zlcook在github创建项目iqas-ios-record Paste_Image.png2.zlcook为项目iqas-ios-record添加合作 查看详情
用git进行协同开发
用Git进行协同开发问题场景描述常常会遇到这样的协同场景:后台的同事和前端的同事需要共同开发一个新功能,而他们的代码相互依赖,所以需要不停地更新各自的代码进行联调。对于这种场景,最简单的方式就是,这2个同... 查看详情
git之多人协同开发
一、获取远程库信息$gitremote-voriginhttps://github.com/xxxxx/node.git(fetch)originhttps://github.com/xxxxx/node.git(push) 二、克隆远程库$gitclonehttps://github.com/fuxinran/node.gitCloninginto‘node‘...remote:Enumerat 查看详情
git&github(代码片段)
Git&GitHub版本控制个人版本控制在进行开发的时候,程序需要经常性的修改,那么修改的时候就存在备份问题,当代码量较大修改频繁时,备份的及时性和备份的困难度就增加了。团队版本控制当团队中多人协同开发同一个功... 查看详情
git与github的使用git最新教程通俗易懂学习——狂神说视频笔记(代码片段)
...们就迫切需要一个版本控制工具!多人开发就必须要使用版本控制ÿ 查看详情
git与github的使用git最新教程通俗易懂学习——狂神说视频笔记(代码片段)
...们就迫切需要一个版本控制工具!多人开发就必须要使用版本控制ÿ 查看详情
git协同开发(代码片段)
Github之协同开发一、协同开发1、引子:假如三个人共同开发同一份代码,每个人都各自安排了任务,当每个人都完成了一半的时候,提交不提交呢?要提交,提交到dev吗,都上传了一半,这样回家拿出来的代码根本跑不起来。... 查看详情
android协同开发篇(git)使用git协同开发之忽略文件
github和git的简单使用
本次主要介绍与实践课程息息相关的小组合作开发,通过github和git可以很好对小组成员的代码进行管理。我邀请刘子义和我分别扮演合作中的项目经理和团队成员两种角色。 首先介绍一下github的主要功能:(1)Git仓库(2)O... 查看详情
初学git
...不同时间备份让后需要时找回其中一份代替,不过更方便使用。GitHub某种程度上就是代码的网盘,也有开源开发商作为代码发布、存放、征集Bug和意见用。2.对GIT和GITHUB的作用使用git和github可以把代码传到云端,可以和别人进行... 查看详情
git&github
Git&GitHub1、版本控制工具应该具备的功能协同修改多人并行不悖的修改服务器的同一个文件数据备份不仅保存目录和文件的当前状态,还能够保存每一个提交过的历史状态状态管理在保存每一个版本的文件信息的时候要做到不... 查看详情