Git工程开发实践五——Git分布式工作流程

Git工程开发实践(五)——Git分布式工作流程

一、Git分布式工作流程简介

与集中式版本控制系统(CVCS)不同,Git的分布式特性使得开发者间的协作变得更加灵活多样。在集中式系统中,每个开发者就像是连接在集线器上的节点,彼此的工作方式大体相同。 而在Git中,每个开发者同时扮演着节点和集线器的角色,即每个开发者既可以将自己的代码贡献到其它的仓库中,同时也能维护自己的公开仓库,让其他人可以在其基础上工作并贡献代码。 因此,Git的分布式协作可以为项目和团队衍生出各种不同的工作流程。常见的Git分布式工作流程有集中式工作流程、集成管理者工作流程、司令官与副官工作流程。

二、Git集中式工作流程

集中式工作流很好地借鉴了集中式版本控制系统的工作模式。集中式工作流通常包含一个中央服务器,可以接受代码;每个开发者作为一个节点,将自己的工作与中央服务器同步。如果两个开发者从中心仓库克隆代码下来,同时作了一些修改,那么只有第一个开发者可以顺利地把数据推送回中央服务器。 第二个开发者在推送修改前,必须先将第一个人的工作合并进来,才不会覆盖第一个人的修改。

Git工程开发实践(五)——Git分布式工作流程


集中式工作流程只需要搭建好一个中心仓库,并给开发团队中的每个人推送数据的权限,就可以开展工作。Git不会让用户覆盖彼此的修改。 例如John和Jessica同时开始工作。 John完成了自己的修改并推送到服务器。 接着Jessica尝试提交自己的修改,却遭到服务器拒绝。Jessica会被告知她的修改正通过非快进式(non-fast-forward)的方式推送,只有将数据抓取下来并且合并后方能推送。
集中式工作流程使用非常广泛,大多数人对其很熟悉也很习惯。但集中式工作流程并不局限于小团队,通过利用Git分支模型管理,通过同时在多个分支上工作的方式,即使上百人的开发团队也可以很好地在单个项目上协作。

三、集成管理者工作流程

Git允许多个远程仓库存在,每个开发者拥有自己仓库的写权限和其他所有人仓库的读权限。集成管理者工作流程中,通常会有个官方项目的权威仓库。如果要为项目做贡献,需要从官方项目克隆(Fork)出一个自己的公开仓库,然后将自己的修改推送到自己的公开仓库;然后可以请求官方仓库的维护者拉取自己公开仓库的更新合并到主项目。维护者可以将贡献者的公开仓库作为远程仓库添加进来,在本地测试贡献者的变更,将其合并入维护者的本地仓库分支并推送到官方仓库。

Git工程开发实践(五)——Git分布式工作流程


集成管理者工作流程工作方式如下:
A、贡献者克隆官方主仓库到自己本地。
B、贡献者在自己本地仓库进行修改,并推送到自己公开仓库。
C、贡献者给维护者发送邮件,请求拉取自己的更新。
D、维护者在自己本地的仓库中,将贡献者的公开仓库加为远程仓库并合并修改。
E、维护者将合并后的修改推送到官方主仓库。
集成管理者工作流程是GitHub和GitLab等在线代码托管工具最常用的工作流程,非常适合社区开源项目的开发。Pull Request和Merge Request就是集成管理者工作流程的最佳工程实践。
贡献者可以容易地将某个项目派生成为自己的公开仓库,向自己的公开仓库推送自己的修改,并为每个人所见。贡献者可以持续地工作,而主仓库的维护者可以随时拉取贡献者的修改。贡献者不必等待维护者处理完提交的更新,每一方都可以按照自己节奏工作 。

四、司令官与副官工作流程

司令官与副官工作流程是多仓库工作流程的变种,通常拥有数百位协作开发者的超大型项目才会使用,例如著名的Linux 内核项目。被称为副官(lieutenant)的各个集成管理者分别负责集成项目中的特定部分。所有副官还有一位上级称为司令官(dictator)的总集成管理者负责统筹。司令官维护的仓库作为参考仓库,为所有协作者提供需要拉取的项目代码。

Git工程开发实践(五)——Git分布式工作流程


司令官与副官工作流程如下:
A、普通开发者在自己的特性分支上工作,并根据司令官的master分支进行变基。
B、副官将普通开发者的特性分支合并到自己master分支中。
C、司令官将所有副官的master分支并入自己master分支中。
D、司令官将集成后的master分支推送到参考仓库中,以便所有其他开发者以此为基础进行变基。
司令官与副官工作流程并不常用,只有当项目极为庞杂或者需要多级别管理时才会体现出优势。利用司令官与副官工作流程,项目总负责人(司令官)可以把大量分散的集成工作委托给不同小组负责人分别处理,然后在不同时刻将大块的代码子集统筹起来,用于后续整合。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Git安装和使用 Git安装和使用 刚开始用git的小白适用,,转自http://www.cnblogs.com/qijunjun/p/7137207.html 实际项目开发中,我们经常会用一些版本控制器来托管自己的代码,今天就来总结下Git的相关用法,废话不多说,直接开写。 目的:通过Git管理g
fatal: remote origin already exists.解决方法 第一个问题git remote add origin**************fatal: remote origin already exists.(报错远程起源已经存在。)上网查了下,有很多小白遇到过这个问题,以
git常用命令(二)查看历史记录 git log [--pretty=oneline] [ --oneline] / reflog Eniac-W 于 2020-10-18 18:12:38 发布 2368 收藏 3分类专栏: git 文章标签: git版权 git专栏收录该内容10 篇文章0 订阅
git之如何把本地文件上传到远程仓库的指定位置 git专栏收录该内容2 篇文章0 订阅订阅专栏2018.11.26添加内容: 对于自己的仓库,我们建议将远程仓库通过clone命令把整个仓库克隆到本地的某一路径下。这样的话我们从本地向远程仓库提交代码时,就可以直接把需要提交的文件拖到我们之前克隆下来的
代码规范之 lint-staged 在代码提交之前,进行代码规则检查能够确保进入git库的代码都是符合代码规则的。但是整个项目上运行lint速度会很慢,lint-staged能够让lint只检测暂存区的文件,所以速度很快。 安装与配置 安装husky和lint-staged: yarn add hu
方法:1、文件没有git操作时用“git checkout--文件”命令还原;2、文件提交到暂存区时用“git reset HEAD”命令回退当前版本还原;3、文件提交到仓库区时用“git reset HEAD^”命令回退上一个版本还原。 本文操作环境:Windows10系统、Git2.30.0版、
使用Git将本地文件提交到远程仓库 一 操作准备条件: git远程仓库已经建好了,本地文件已经存在了,现在要将本地代码推到git远程仓库保存。 解决办法如下: 1、(先进入项目文件夹)通过命令 git init 把这个目录变成git可以管理的仓库 git init 2、把文件添加到版本库中,使用命令
GitHub克隆代码到本地全教程 因为工作原因更换电脑,想要从GitHub上拉取代码的话需要重新配置ssh keys,时间过的久了怕忘记就把步骤给记录下来。 具体步骤: 1.安装git 这我就不说了 2.在TortoiseGit的安装文件中找到 puttygen.exe应用程序 ,默认应该都是 :C
github上传项目的时候报出git@github.com: Permission denied (publickey). fatal: Could not read from remote repo 前言 会不会有程序员小伙伴在刚开始使用github的时候上传项目的时候困难重重,但是又基于自己本身
查看历史 git log --pretty=onelinegit log (然后一直按enter键) 一个是切换根据历史里面的id切换git checkout ID git log 需要不断按enter键出来历史提交记录 git log --pretty=oneline 是直接出来历史记录
Git工作原理及常用命令 欧怼怼发布于 2020-12-08 git介绍 git(读音/ɡɪt/)是一个开源的分布式版本控制系统,可以有效、高速地处理从很小到非常大的项目版本管理。git是Linus Torvalds为了帮助管理Linux内核开发而开发的一个开放源码的版本控制软件。 git
git git提交项目的具体流程 git项目流程:以下主要有3个角色:负责人、成员A、成员B(若负责人也要修改代码,则负责人同时兼任2个角色:负责人、成员) 主要负责人:搭建项目架构且提交到git上1.github官网登录后,新建仓库,生成地址url,复制线上仓库.git结尾的地址url2.在一个空
git上传项目全部流程 一、下载git 进入网址:https://git-scm.com/downloads; 点击中的Download 2.16.0 for Windows; 在中选择蓝色字段点击,根据电脑64或32位选择适合的下载,点击即可进行下载,下载完成后傻瓜式安装,一直点击下一步即可完成安
Your local changes to the following files would be overwritten by checkout问题的解决 于 2018-07-17 11:38:27 发布 Git 的本地版本管理有三个部分 名称	说明工作区(Working Directory)	
Git配置SSH Keys步骤使用教程 1.若是首次安装使用git,先配置用户名称和邮箱(如果有就不需要配置) 打开Git Bash,输入 git config --global user.name "姓名"git config --global user.email &quot
基本配置完成,接下来就是上传你要上传的项目了。 1、初始化git 进入你要上传的项目的文件夹,在文件夹内鼠标右击,选择“Git Bash Here”打开git命令行,输入: $ git init 目的是初始化git,并且会创建个“.git”文件夹,里面有个“config”就是用来保存远程厂库路径地址
本篇内容主要讲解“gitee如何上传代码”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“gitee如何上传代码”吧! ...
这篇“从gitee上下的代码如何用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这...
这篇文章主要介绍“gitee如何下载仓库里的项目”,在日常操作中,相信很多人在gitee如何下载仓库里的项目问题上存在疑惑,小编查阅了各式资料,整理出简单好用的...
本篇内容主要讲解“怎么在Gitee上更新代码”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么在Gitee上更新代...