git协同开发

作者: sarafina527 | 来源:发表于2016-10-21 14:24 被阅读0次

1.两人协同

以主角A和B为例,

  1. A着手开发test库,并用git管理;
  2. A邀请B参与test库;
  3. B通过克隆局域网中的A的test库
B> cd work
B> git clone A@192.168.0.7:~/work/test test
git-clone可利用各种网络协议访问远端机器中的Git仓库,从中导出完整的工作树到本地。
B通过SSH协议访问了A机器上的A账户的test仓库并进行导出,从而在当前目录下建立了test工作树,克隆的仓库名默认原仓库名,所以最后一个test可以省略。
如远端仓库地址 match 账户@IP:工作树路径 git clone使用SSH协议。
  1. A、B各自对各自机器上的test仓库进行修改、提交。
  2. 当需要合并时,一般在主要开发者A机器上进行合并,(但同一项目的不同仓库地位均等)。A需要合并B的工作,执行以下git pull
> cd ~/work/test
> git pull B@192.168.0.5:~/work/test
在A的test仓库中完成对B机器上的test仓库的合并。

git-pull命令可将属于同一项目的远端仓库与同样属于同一项目的本地仓库进行合并.它包含了两个操作:
1).从远端仓库中取出更新版本
2).然后合并到本地仓库。
如果A与B是对了不同的文件进行了改动,那么可以不费周折地完成仓库合并。但是倘若二人对一些相同的文件进行了改动,那么在合并时必然会遭遇合并冲突的问题,此时手动修改发生合并冲突的文件,然后将结果提交到本地仓库。

2.解决冲突

虽然A与B是对同一份文件进行了修改,但是他们的修改并未重叠。现在假设二人对同一文件的同一行做出了修改,那么在仓库合并时会发生冲突,举个栗子,初始foo.txt如下:

one
two
three

A将foo文件的第一行改为大写,B在foo文件第一行加了大写,发生冲突,合并之后的foo文件如下:

<<<<<<< HEAD:foo
ONE
=======
one ONE
>>>>>>> 1116d3270764d91a25532a753a47b8b0e1b6f1b8:foo
two    
three

以一串<+HEAD开头和一串>+版本号结束的字串表示冲突部分,而正文第一行ONE表示A的修改结果,中间用了一串=号将二人修改结果隔开,后面一行表示B的当前项目版本对foo.txt的修改结果。
而后主研A可根据现实情况将冲突解决掉,即修改冲突部分,手动选择保留哪一个结果,并删除其他部分,最后将合并处理结果提交到仓库。

3.多人协同

若还有C、D加入这个项目,他们也需要克隆一份项目仓库,然后修改提交,最后由A一一取回BCD三人的仓库,在合并完成一个协同周期。这样导致A的合并处理负担太重,可以分摊到其他人。
Git提供了git-pull的对偶命令:git-pushgit-pull命令负责从远端仓库取回版本更新,而git-push可将本地版本更新推送到远端仓库中

BCD的工作流程
$ git clone A@192.168.0.7:~/work/test
...项目开发...
$ git add改动的文件
$ git commit
$ git pull
...解决版本合并问题...
$ git push

BCD等人需要克隆一份,然后进行开发和本地版本管理,然后从A(或服务器)取得团队最新版本,然后与本地的进行合并,最后推送到A(服务器)。

4.多人协同优化

上个栗子中,A是个项目参与人,但与其他人员又具有相当大差距,因为A的电脑起到了服务器的汇总功能,所以他不需要pull或者push,这样的特权不合理。这里的方案是将汇总的仓库建立在另外的服务器上。

相关文章

  • git协同开发

    1.两人协同 以主角A和B为例, A着手开发test库,并用git管理; A邀请B参与test库; B通过克隆局域...

  • Git

    Git有什么用 保存开发中的版本历史,并能回退 协同开发 Git 全局配置 s git config --glob...

  • Git

    GIT 有什么用 保存开发中的版本历史,并能回退 协同开发 Git 全局配置 s git 初始化命令 git in...

  • Git

    GIT 有什么用 保存开发中的版本历史,并能回退 协同开发 Git 全局配置 git 初始化命令 git init...

  • Android Studio 与Git 上传项目与下载项目流程

    Android Studio 多人协同开发(Git版)——Windows平台 一、首次上传项目流程: 安装Git(...

  • 版本控制工具:Git

    Git是什么? Git是应用于多人协同开发的分布式版本控制工具,主要功能是协同开发和版本控制,实现这些功能最主要的...

  • Git之协同开发

    协同开发一般有两种方式:1、合作者,将其他用户添加到仓库合作者之后,该用户就可以向当前仓库提交代码。 2、组织,创...

  • Git基础

    一、简介 方便多人协同开发 方便版本控制 作者Linux之父:Linus Torvalds git开发目的:为了辅...

  • IDEA中常见的git操作

    不知不觉,svn已经退居历史,git闪亮登场。现在的项目多人协同开发,首选git,开发工具idea用的比较多,所以...

  • 团队项目的Git分支管理规范

    团队项目的Git分支管理规范 许多公司的开发团队都采用Git来做代码版本控制。如何有效地协同开发人员之间,以及开发...

网友评论

    本文标题:git协同开发

    本文链接:https://www.haomeiwen.com/subject/lnoquttx.html