使用git进行团队合作开发

1.git 和 svn 的差异

git和svn 最大的差异在于git是分布式的管理方式而svn是集中式的管理方式。如果不习惯用代码管理工具,可能比较难理解分布式管理和集中式管理的概念。下面介绍两种工具的工作流程(团队开发),通过阅读下面的工作流程,你将会很好的理解以上两个概念。

集中式管理的工作流程如下图(图2.1):

  集中式代码管理的核心是服务器,所有开发者在开始新一天的工作之前必须从服务器获取代码,然后开发,最后解决冲突,提交。所有的版本信息都放在服务器上。如果脱离了服务器,开发者基本上是不可以工作。下面举例说明:

开始新一天的工作:

1:从服务器下载项目组最新代码。

2:进入自己的分支,进行工作,每隔1个小时向服务器自己的分支提交一次代码(很多人都有这个习惯。因为有时候自己对代码改来改去,最后又想还原到前一个小时的版本,或者看看前一个小时自己修改了哪些代码,就需要这样做了)。

3:下班时间快到了,把自己的分支合并到服务器主分支上,一天的工作完成,并反映给服务器。

这就是经典的svn工作流程,从流程上看,有不少缺点,但也有优点。

缺点:

1、服务器压力太大,数据库容量暴增。

2、如果不能连接到服务器上,基本上不可以工作,看上面第二步,如果服务器不能连接上,就不能提交,还原,对比等等。

3、不适合开源开发(开发人数非常非常多,但是Google app engine就是用svn的)。但是一般集中式管理的有非常明确的权限管理机制(例如分支访问限制),可以实现分层管理,从而很好的解决开发人数众多的问题。

优点:

1、管理方便,逻辑明确,符合一般人思维习惯。

2、易于管理,集中式服务器更能保证安全性。

3、代码一致性非常高。

4、适合开发人数不多的项目开发。

5、大部分软件配置管理的大学教材都是使用svn 和vss。

下面是分布式管理的工作流程,如下图(图2.2):

  分布式和集中式的最大区别在于开发者可以在本地提交。每个开发者机器上都有一个服务器的数据库。

  图2.2就是经典的git开发过程。步骤如下:

一般开发者的角度:

1:从服务器上克隆数据库(包括代码和版本信息)到单机上。

2:在自己的机器上创建分支,修改代码。

3:在单机上自己创建的分支上提交代码。

4:在单机上合并分支。

5:新建一个分支,把服务器上最新版的代码fetch下来,然后跟自己的主分支合并。

6:生成补丁(patch),把补丁发送给主开发者。

7:看主开发者的反馈,如果主开发者发现两个一般开发者之间有冲突(他们之间可以合作解决的冲突),就会要求他们先解决冲突,然后再由其中一个人提交。如果主开发者可以自己解决,或者没有冲突,就通过。

8:一般开发者之间解决冲突的方法,开发者之间可以使用pull命令解决冲突,解决完冲突之后再向主开发者提交补丁。

主开发者的角度(假设主开发者不用开发代码):

1:查看邮件或者通过其它方式查看一般开发者的提交状态。

2:打上补丁,解决冲突(可以自己解决,也可以要求开发者之间解决以后再重新提交,如果是开源项目,还要决定哪些补丁可用,哪些不用)。

3:向公共服务器提交结果,然后通知所有开发人员。

优点:

适合分布式开发,强调个体。

公共服务器压力和数据量都不会太大。

速度快、灵活。

任意两个开发者之间可以很容易的解决冲突。

缺点:

资料少(起码中文资料很少)。

学习周期相对而言比较长。

不符合常规思维。

代码保密性差,一旦开发者把整个库克隆下来就可以完全公开所有代码和版本信息。

2.git常用命令介绍

git init

创建一个数据库

git clone

复制一个数据到制定文件夹

git add 和git commit

把想提交的文件add上,然后commit这些文件到本地数据库。

git pull

从服务器下载数据库,并跟自己的数据库合并。

git fetch

从服务器下载数据库,并放到新分支,不跟自己的数据库合并。

git whatchanged

查看两个分支的变化

git branch

创建分支,查看分支,删除分支

git checkout

切换分支

git merge

合并分支,把目标分支合并到当前分支

git config

配置相关信息,例如email和name

git log

查看版本历史

git show

查看版本号对于版本的历史,如果参数是HEAD查看最新版本。

git tag

标定版本号

git reset

恢复到之前的版本

--mixed是git-reset的默认选项,它的作用是重置索引内容,将其定位到指定的项目版本,而不改变你的工作树中的所有内容,只是提示你有哪些文件还未更新。

--soft选项既不触动索引的位置,也不改变工作树中的任何内容。该选项会保留你在工作树中的所有更新并使之处于待提交状态。相当于在--mixed基础上加上git add。

--hard 把整个目录还原到一个版本,包括所有文件。

git push

向其他数据库推送自己的数据库

git status

显示当前的状态

git mv

重命名文件或者文件夹

git rm

删除文件或者文件夹

git help

查看帮助,还有几个无关紧要的命令,请自己查看帮助。

3.git开发模式

1:大项目开发模式(如图4.1)

对于项目负责人

1:初始化

对于最终项目负责人:

使用git init --bare在公共服务器上建立一个空数据库,在自己的机器上通过

或者数据库(这里需要设置一下访问权限,由于git没有提供权限管理功能,所以要通过ssh设置,具体是对下一级子项目项目可读不可写,对自己可读可写)。

新建一些必要的文件夹和文件放到自己的数据库上

然后使用

提交到公共服务器上,作为原始版本。

告诉下级公共服务器的地址。

对于子项目负责人:

在子公共服务器上克隆一个数据库

设置访问权限,对下级可读不可写,对自己可读可写。
在自己的计算机中克隆一个数据库

告诉下级子公共服务器地址。

对于最底层的开发人员:
在上级公共服务器中克隆一个数据库

2:开展工作
对于最终项目负责人
收来自下级的邮件
在自己的数据库上建分支,并转到分支上

重复上述步骤,直到所有补丁打完。
如果发现在合并分支的时候发现有些冲突需要下级项目负责人协助解决的话,可以通知下级项目负责人。
对于子项目负责人:
如果上级项目负责人需要他们之间合作解决某些冲突,他们可以通过

解决冲突。
如果上级项目负责人没有要求合作解决冲突,那项目负责人应该做以下事情:

然后项目负责人就开始接收邮件,然后打补丁

重复上述工作,直到补丁全部打完。
下面是向上级提交更新的过程

对于最底层的开发人员:
如果上级要求解决冲突,同样是要解决冲突,然后再提交补丁

如果不用,就从上级服务器更新

然后建分支,并开发代码

然后是向上级提交代码

以上就是git在大项目开发中的应用。
但是明显是不适合我们实验室的。
原因有三:
1、我们学生中没有专门的维护人员。
2、我们学生中没有对全局都很了解架构师。
3、我们的老师可以担当此重任也只有我们的老师有这样的实力,但是老师太忙,没时间每天做这些琐事。
所以我们需要一种新的合作模式(一种没有项目负责人的模式)。

这种模式对开发人员的素质要求很高。
合作模式如下图(图4.2):(适合我们实验室使用)

这种模式的开发流程如下:
1、由其中一个开发者这服务器上建立一个数据库。
所有开发者都可以向数据库提交和下载东西,这里必须规定一定的时间间隔(一周或者一天)必须提交一次,不然以后解决冲突时是个大问题。
如果每个人的开发耦合度很高,我们可在服务器上建立分支,然后每人每次提交到自己的分支上,过一段时间之后(不能太久)有一个人去合并分支。然后所有人更新自己的数据库的master分支,使之跟服务器上的master分支同步。
2、这样服务器会有非常多的版本信息,集合了每个人的版本信息。
过了一段时间之后,例如有里程碑的出现。再由一个人把所有改动打补丁到最终服务器上。这样最终服务器的版本信息就会很精练。
3、当我们的服务器无限膨胀到一定程度的时候我们可以把它删除,然后用最终服务器上的一个版本作为起始版本。

时间: 2024-10-09 18:31:39

使用git进行团队合作开发的相关文章

axure团队合作开发原型图

以前都是组长或者其他一个人画原型图,但是在开发基础系统时,我们分拨一部分人画原型,一部分干其他的.这时画原型不再是一个人画了,是几个人一起画,如果大家都各自画自己那一部分,最后再由一个人来整合的画,是很麻烦.咱平时团队开发项目时经常用svn来管理,那画原型是不是也可以,答案是可以的. 如何也用svn来管理呢,请看下面: 1.首先在svn服务器上创建好新的库,然后复制地址.给每个组员创建用户和分配权限. 2.打开原型工具axure,可以在"文件"里选择"新建共享工程"

git团队合作开发流程

关于git的环境配置在以前已说过就不罗索了,这里介绍在公司如何团队一起开发项目 首先你需要把你的秘钥给管理员,如何配置以前介绍过了就不说了 进入正题:git ls-files查看当前厂库被add得所有文件git push origin :branchname 删除远程的branchname分支git branch -a 查看远程有哪些分支git branch 查看本地有哪些分支git branch -D branchname 删除本地的branchname分支 个人git开发流程git bran

小白也能用Git管理团队项目了:百度云同步+Git Extensions+Git Source Control Provider

百度云同步 百度云同步,会将本地的某个文件目录和云端进行同步.如果在本地将这个同步的目录设置为Git的中心服务器,那么本地push到中心服务器的内容也会被同步到云端.其他开发者只要也进行相同的设置,就能够进行合作开发. 下面使用一个远程和本机来模拟两个开发者,先是安装云同步. Git远程仓库命令 新建中心服务器 先在同步目录中创建一个MyTest的项目文件夹. 然后使用“git init --bare”来建立中心仓库,中心仓库会自动同步到云端.到这里一个空的中心服务器就建好了. clone一个仓

Git搭建团队开发环境操作演练

模拟创建远程git仓库 1.首先创建如下目录结构: /Users/hujh/Desktop/GitTest2/GitServer/weibo weibo是我们要创建的项目 2.切换目录 $ cd /Users/hujh/Desktop/GitTest2/GitServer/weibo 3. 建立空白代码库(专门用于团队开发) $ git init —bare 正常一般能显示类似如下结果代表初始化空仓库成功 Initialized empty Git repository in /Users/hu

Git搭建团队项目环境

序言 使用git有一段时间但是没有自己搭过项目.当我在网络查找问题时,搜到的同类文章大同小异,表述也不是很详细. 被push失败问题折腾了6个小时,于是完整决定记录一下,不尽完善,公自己和新手参考. 系统Mac OS X  Yosimite 10.10----------------------------------------------------------------------------------------------------- 一.项目中心仓库部分 中心仓库需要设为裸仓库

Git 在团队中的最佳实践--如何正确使用Git Flow

我们已经从SVN 切换到Git很多年了,现在几乎所有的项目都在使用Github管理, 本篇文章讲一下为什么使用Git, 以及如何在团队中正确使用. Git的优点 Git的优点很多,但是这里只列出我认为非常突出的几点. 由于是分布式,所有本地库包含了远程库的所有内容. 优秀的分支模型,打分支以及合并分支,机器方便. 快速,在这个时间就是金钱的时代,Git由于代码都在本地,打分支和合并分支机器快速,使用个SVN的能深刻体会到这种优势. 感兴趣的,可以去看一下Git本身的设计,内在的架构体现了很多的优

Git 在团队中的最佳实践--如何正确使用Git Flow[转]

原文地址:http://www.cnblogs.com/cnblogsfans/p/5075073.html Git的优点 Git的优点很多,但是这里只列出我认为非常突出的几点. 由于是分布式,所有本地库包含了远程库的所有内容. 优秀的分支模型,打分支以及合并分支,机器方便. 快速,在这个时间就是金钱的时代,Git由于代码都在本地,打分支和合并分支机器快速,使用个SVN的能深刻体会到这种优势. 感兴趣的,可以去看一下Git本身的设计,内在的架构体现了很多的优势,不愧是出资天才程序员Linus (

团队合作开发APP——程序测试

 在团队合作中我的主要任务是辅助程序测试,而测试的目的是为了发现尽可能多的缺陷,不是为了说明软件中没有缺陷,同时成功的测试在于发现了迄今尚未发现的缺陷.所以测试人员的职责是设计这样的测试用例,它能有效地揭示潜伏在软件里的缺陷. 一般情况下,在分析.设计.实现阶段的复审和测试工作能够发现和避免80%的Bug,而系统测试又能找出其余Bug中的80%,最后的5%的Bug可能只有在用户的大范围.长时间使用后才会曝露出来.因为测试只能够保证尽可能多地发现错误,无法保证能够发现所有的错误.所以这需要测试人员

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

此篇文章只是一篇傻瓜式的,记录工作中比较规范且常见的一个git工作流需要用到的命令,让你可以快速的开始工作.而不是一些长篇大论的理论知识,如果你有用过sourcetree或者其它图形化工具,结合你正在使用的工具,敲这些命令,看图形化工具中的变化,对比思考这些命令可能会更容易吸收. 1.基本配置 刚入职公司开始做项目拉代码,需要经历的第一件事.配置个人的用户名称和电子邮件地址(通常是公司邮件地址) 1.1 配置用户名和邮箱 git config --global user.name "你的名字&q