`
zjjzmw1
  • 浏览: 1366314 次
  • 性别: Icon_minigender_1
  • 来自: 开封
社区版块
存档分类
最新评论

git 使用简介

    博客分类:
  • iOS
git 
阅读更多

 

git 使用简介
单位: 华中科技大学服务计算技术与系统 / 集群与网格计算实验室

简介: 作者是华中科技大学 2010 级计算机学院计算机系统结构专业研究生

一、简介:

网上找到的 git 的中文资料,大部分是讲 git 的命令的使用,对于 git 的工作流程和如何 实现团队合作的介绍少之又少,特别是对于团队代码库管理者的文档,几乎没有,这份文档 将从开发者和管理者两方面介绍如何使用 git 进行团队合作开发。

二、 git svn 的差异
git svn 最大的差异在于 git 是分布式的管理方式而 svn 是集中式的管理方式。如果不

习惯用代码管理工具,可能比较难理解分布式管理和集中式管理的概念。下面介绍两种工具 的工作流程(团队开发),通过阅读下面的工作流程,你将会很好的理解以上两个概念。

指导老师:邵志远
作者: 卓达城
邮箱:
zhuodc@qq.com

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

开发者

开发者

commit get

开发者

get commit

commit
get

服务器

2.1 集中式代码管理的核心是服务器,所有开发者在开始新一天的工作之前必须从服务器获

取代码,然后开发,最后解决冲突,提交。所有的版本信息都放在服务器上。如果脱离了服 务器,开发者基本上是不可以工作。下面举例说明:
开始新一天的工作:
1 :从服务器下载项目组最新代码。 2 :进入自己的分支,进行工作,每隔一个小时向服务器自己的分支提交一次代码(很多人

都有这个习惯。因为有时候自己对代码改来改去,最后又想还原到前一个小时的版本,或者 看看前一个小时自己修改了那些代码,就需要这样做了)。 3 :下班时间快到了,把自己的分支合并到服务器主分支上,一天的工作完成,并反映给服 务器。

这就是经典的 svn 工作流程,从流程上看,有不少缺点,但也有优点。
缺点:
1 、 服务器压力太大,数据库容量暴增。
2 、 如果不能连接到服务器上,基本上不可以工作,看上面第二步,如果服务器不能连接上, 就不能提交,还原,对比等等。

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

优点:
1 、 管理方便,逻辑明确,符合一般人思维习惯。
2 、 易于管理,集中式服务器更能保证安全性。
3 、 代码一致性非常高。
4 、 适合开发人数不多的项目开发。 5 、大部分软件配置管理的大学教材都是使用 svn vss

下面开分布式管理的工作流程,如下图(图 2.2 ): 公共服务器

pull/fetch

pull/fetch

发送补丁

主开发者

本地提交

pull/fetch 开发者

解决冲突 本地提交

发送补丁

开发者

本地提交

2.2

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

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

push

一般开发者的角度:
1 :从服务器上克隆数据库(包括代码和版本信息)到单机上。 2 :在自己的机器上创建分支,修改代码。
3 :在单机上自己创建的分支上提交代码。
4 :在单机上合并分支。
5 :新建一个分支,把服务器上最新版的代码 fetch 下来,然后跟自己的主分支合并。 6 :生成补丁( patch ),把补丁发送给主开发者。 7 :看主开发者的反馈,如果主开发者发现两个一般开发者之间有冲突(他们之间可以合作 解决的冲突),就会要求他们先解决冲突,然后再由其中一个人提交。如果主开发者可以自 己解决,或者没有冲突,就通过。 8 :一般开发者之间解决冲突的方法,开发者之间可以使用 pull 命令解决冲突,解决完冲突 之后再向主开发者提交补丁。

主开发者的角度(假设主开发者不用开发代码): 1 :查看邮件或者通过其它方式查看一般开发者的提交状态。 2 :打上补丁,解决冲突(可以自己解决,也可以要求开发者之间解决以后再重新提交,如 果是开源项目,还要决定哪些补丁有用,哪些不用)。 3 :向公共服务器提交结果,然后通知所有开发人员。

优点:
适合分布式开发,强调个体。
公共服务器压力和数据量都不会太大。
速度快、灵活。
任意两个开发者之间可以很容易的解决冲突。
离线工作。


缺点:
资料少(起码中文资料很少)。
学习周期相对而言比较长。
不符合常规思维。 代码保密性差,一旦开发者把整个库克隆下来就可以完全公开所有代码和版本信息。

三、 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

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


四、 git 开发模式
1 :大项目开发模式(如图 4.1 )(不适合我们实验室使用)

公共服务器

push/pull

子公共服务器

一般开发人员

push/pull

总项目负责人

邮件提交 / 反馈

pull/fetch/ clone

邮件提交 / 反馈

子项目负责人

邮件提交 / 反馈

邮件提交 / 反馈

子项目负责人

协商解决冲突

子公共服务器

push/pull

邮件提交 / 反馈

邮件提交 / 反馈

pull/fetch/ clone

pull/fetch/ clone

一般开发人员

协商解决冲突

一般开发人员

协商解决冲突

一般开发人员

对于项目负责人
1 :初始化
对于最终项目负责人:
使用
git init --bare 在公共服务器上建立一个空数据库,在自己的机器上通过

git pull 公共服务器 ip 地址 : 数据库所在文件夹

4.1

获得数据库(这里需要设置一下访问权限,由于 git 没有提供权限管理功能,所以要通过 ssh 设置,具体是对下一级子项目经理可读不可写,对自己可读可写)。 新建一些必要的文件夹和文件在放到自己的数据库上

新建文件

git add . git commit

然后使用
git push 公共服务器 ip 地址 : 数据库所在文件夹 master

提交到公共服务器上,作为原始版本。
告诉下级公共服务器的地址。


对于子项目负责人:

在子公共服务器上克隆一个数据库
git clone 上级公共服务器 ip 地址 : 数据库所在文件夹

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


git clone 同级公共服务器 ip 地址:数据库所在文件夹

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


对于最底层的开发人员:

在上级公共服务器中克隆一个数据库
git clone 上级公共服务器 ip 地址 : 数据库所在文件夹

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

git branch temp
git checkout temp
打补丁( patch 命令)
git whatchanged master temp git add .

git commit
git checkout master
git merge master temp
git push
公共服务器 ip 地址 : 数据库所在文件夹 通知下级人员已经更新

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

对于子项目负责人: 如果上级项目负责人需要他们之间合作解决某些冲突,他们可以通过

git fetch 子项目负责人服务器 ip 地址 : 数据库所在文件夹 master:temp git merge temp
解决冲突
git add .

git commit
git branch -d temp
删除分支
git fetch 上级项目公共服务器 ip 地址 : 数据库所在文件夹 master:temp git merge temp 保证代码是最新的
git diff master temp > patch
发补丁给上级

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

git pull 上级项目公共服务器 ip 地址 : 数据库所在文件夹 解决冲突
git push 对应的公共服务器 ip 地址 : 数据库所在文件夹 通知下级人员服务器已经更新

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


git branch temp
git checkout temp
打补丁( patch 命令)
git whatchanged master temp git add .
git commit
git checkout master
git merge temp
git branch -d temp

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


git fetch 上级项目公共服务器 ip 地址 : 数据库所在文件夹 master:temp git merge temp 保证代码是最新的。
git diff temp master > patch
发邮件提交补丁

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


git fetch 对应开发人员的服务器 ip 地址 : 数据库所在文件夹 master:temp git merge temp
解决冲突
git add .

git commit
git branch -d temp
删除分支
git fetch 上级项目公共服务器 ip 地址 : 数据库所在文件夹 master:temp git merge temp 保证代码是最新的
git diff master temp > patch
发补丁给上级

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


git pull 上级项目公共服务器 ip 地址 : 数据库所在文件夹 解决冲突

然后建分支,并开发代码

git branch xxx
git checkout xxx
开发
git checkout master git merge xxx

然后是向上级提交代码

git fetch 上级项目公共服务器 ip 地址 : 数据库所在文件夹 master:temp git merge temp 保证代码是最新的。
git diff temp master > patch
发邮件提交补丁

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

所以我们需要一种新的合作模式(一种没有项目负责人的模式)。 这种模式对开发人员的素质要求很高。
合作模式如下图(图
4.2 ):(适合我们实验室使用)

最终服务器

push/pull

服务器

pull

开发者 图 4.2

打补丁

push/pull

push

解决冲突

开发者

开发者

解决冲突

解决冲突

这种模式的开发流程如下:
1 、由其中一个开发者这服务器上建立一个数据库。 所有开发者都可以向数据库提交和下载东西,这里必须规定一定的时间间隔(一周或者一天) 必须提交一次,不然以后解决冲突时是个大问题。

如果每个人的开发耦合度很高,我们可在服务器上建立分支,然后每人每次提交到自己 的分支上,过一段时间之后(不能太久)有一个人去合并分支。然后所有人更新自己的数据 库的 master 分支,使之跟服务器上的 master 分支同步。

2 、这样服务器会有非常多的版本信息,集合了每个人的版本信息。 过了一段时间之后,例如有里程碑的出现。再由一个人把所有改动打补丁到最终服务器上。 这样最终服务器的版本信息就会很精练。

3 、当我们的服务器无限膨胀到一定程度的时候我们可以把它删除,然后用最终服务器上的 一个版本作为起始版本。

五、通过 ssh 进行权限管理 这个问题在第一版暂时不讲。目的是规定哪些人可以对服务器做什么事情(读?写?)。

  • git.pdf (186.1 KB)
  • 下载次数: 1
分享到:
评论

相关推荐

    Git使用简介.pptx

    Git 使用简介 Git 是一个版本控制系统,允许用户追踪文件的变化历史,并且能够在不同的开发分支之间进行切换和合并。本文档将对 Git 的基本概念和使用方法进行介绍,并对 Git 的分支模型进行详细的解释。 Git 的...

    git使用简介ppt

    ### Git使用简介及关键知识点 #### 一、Git介绍及其特点 **Git** 是一个开源的分布式版本控制系统,被广泛应用于软件开发过程中,用于高效地管理和跟踪计算机文件的各种变动。Git 最初由 Linus Torvalds 开发,...

    git使用简介

    ### Git使用简介与核心知识点详解 #### Git概览 Git是一种高效、开源且分布式的版本控制系统,被广泛应用于敏捷开发环境中。与传统的集中式版本控制系统如Subversion(SVN)、CVS或Perforce相比,Git提供了更为...

    Git使用简介ppt.pptx

    git培训使用的ppt,介绍git原理、git基本操作、git的多种状态及多人协作流程规范、git的工具使用等

    GIT使用简介

    比较完善的一个GIT介绍PPT、包括git的简介、命令的使用、安装需要的软件、及参考资料。

    git使用参考文档

    Git是当今最流行的分布式版本控制系统,它在软件开发领域中起着至关重要的...通过阅读"Git的配置与使用.doc"、"svn与Git比较.doc"和"git使用简介(第一版).pdf"这些文档,你可以更深入地理解Git的使用和它与SVN的对比。

    git培训资料

    其次,"git使用简介(第一版)"作为入门指南,可能会详细解析Git的基本操作流程,并提供实例演示,帮助读者掌握在实际项目中运用Git的方法。这部分内容可能涵盖创建新项目、远程仓库的链接、代码同步和分支策略等。...

    Git使用教程(电子书)

    #### 一、Git简介与应用场景 **Git** 是一款开源的分布式版本控制系统,用于跟踪在软件开发过程中对文件所做的更改。它最初由Linus Torvalds于2005年创建,目的是为了更高效地管理Linux内核的源代码。 #### 二、...

    gitblit及使用教程

    1. **Gitblit简介** Gitblit以其简洁的界面和易用性赢得了用户的喜爱。它不仅支持本地运行,还可以作为独立服务器部署,适用于小型团队或个人项目管理。Gitblit提供了REST API,可以与其他系统集成,实现自动化操作...

    Git 命令学习文档(集合整理)

    最后,"Git 使用简介.pdf"可能是针对Git初学者的指南,涵盖了Git的基本概念、安装、配置以及日常使用流程。这份文档可能会强调Git的分布式特性,解释SHA哈希值的重要性,以及如何有效地进行团队协作,如设置用户信息...

    Git 管理工具和操作文档(msysgit for windows)

    "Git 使用简介.pdf"文档很可能包含了更详细的Git使用教程,涵盖了从安装到日常使用的各种操作。这些操作可能包括但不限于: 1. **安装msysGit**:通常,运行.exe文件并按照向导指示进行操作即可完成安装。 2. **...

    git使用手册.doc

    #### 一、Git简介与版本控制系统概念 **Git** 是一款全球范围内使用最为广泛且先进的分布式版本控制系统。它能够自动记录每次文件的改动情况,包括文件的添加、修改以及删除等操作。对于软件开发团队而言,这种能力...

    GIT使用入门.pdf

    #### 一、Git简介与应用场景 **Git** 是一款开源的分布式版本控制系统,用于跟踪在软件开发过程中对文件所做的更改。它最初由Linus Torvalds于2005年创建,目的是为了更高效地管理Linux内核的源代码。 #### 二、...

    GIT相关书籍下载 Git+使用教程 Git权威指南 01链接

    压缩包包含以下几个pdf文件 由于大小有限制,需下载02链接,搜索方式 GIT相关书籍下载 Git+使用教程 Git权威指南 ...git简介.pdf pro_git_中文版本.pdf TortoiseGit日常使用指南.pdf 分布式版本控制系统-Git详解.pdf

    git官方使用手册

    - **GitHub简介:** GitHub是全球最大的开源代码托管平台之一,支持Git仓库托管服务,并提供了一系列增强功能,如问题跟踪、代码审查等。 - **GitHub的影响力:** 截至目前,GitHub已经拥有超过1000万的托管项目,近...

    git下载安装使用

    git的简介文档,软件安装,Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。 Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。 Git 与常用的...

Global site tag (gtag.js) - Google Analytics