任务列表:

有一个中央库Center,和三个工作站A,B,C。

初始化时,代码存放在中央库中,A,B,C三个工作站开始工作之前都要首先从中央库克隆一份代码到本地。

第一个任务:A和B合作修复一个缺陷,要求是A先开始修复,B在A修复的基础上接着修复,然后由B把修改好的缺席推送到中央库的master上。

第二个任务:C在中央库的基础上新建一个分支开始自己的开发,并把自己新建的分支推送到中央库。

第三个任务:A和B合作修复好第一个缺席之后,A自己单独修复第二个缺席,并推送到中央库的master分支上。

第四个任务:B要等A修复完第二个缺陷和C开发完自己的代码后,把中央库上的master分支和C推送的分支合并,并推送回中央库的master分支。

1.中央库

①初始化中央库,并执行一次提交

  1. $ git init
  2. Initialized empty Git repository in /home/greta/GitTest/Center/.git/
  3. $ git add .
  4. $ git commit -m "new file a"

图示如下: 

②wsB第一次推送后,中央库的变化

图示如下:

③wsC推送后,中央库的变化

图示如下:

④wsA推送后,中央库的变化:

⑤wsB第二次推送后,中央库的变化

2.工作站A的操作

①克隆中央库到工作站A

  1. $ git clone /home/greta/GitTest/Center/.git/ wsA
  2. Cloning into wsA...
  3. done.

从Git服务器克隆数据时,Git 会自动为你将此远程仓库命名为 origin ,并下载其中所有的数据,建立一个指向它的master 分支的指针,在本地命名为 origin/master ,但你无法在本地更改其数据。接着,Git 建立一个属于你自己的本地 master 分支,始于 origin 上 master 分支相同的位置,你可以就此开始工作。

图示如下: 

②在工作站A上建立一个branch testA,并把指针切换到testA上。

  1. $ git checkout -b testA
  2. Switched to a new branch 'testA'

这里的命令$ git chekout -b testA实际上是两个命令的合并,相当于执行:

$git branch testA

$git checkout testA

图示如下(*表示当前wsA上head指针的位置): 

③在wsA上执行一次提交

  1. $ git add .
  2. $ git commit -m "submit on wsA(second)"

图示如下:

3.工作站B上的操作

①克隆中央库到工作站B

  1. $ git clone /home/greta/GitTest/Center/.git/ wsB
  2. Cloning into wsB...
  3. done.

图示如下:

②把工作站A的远程分支testA添加到工作站B,并把wsA上分支testA上的数据合并到本机的master上

  1. $ git remote add wsA /home/greta/GitTest/wsA/.git
  2. $ git fetch wsA
  3. remote: Counting objects: 5, done.
  4. remote: Total 3 (delta 0), reused 0 (delta 0)
  5. Unpacking objects: 100% (3/3), done.
  6. From /home/greta/GitTest/wsA/
  7. * [new branch]      master     -> wsA/master
  8. * [new branch]      testA      -> wsA/testA
  9. $ git merge wsA/testA
  10. Updating 20f3246..eb0f47b
  11. Fast-forward
  12. a.txt |    1 +
  13. 1 files changed, 1 insertions(+), 0 deletions(-)

用$git remote add命令添加远程分支时,会把远程机器上所有的分支都加载到本地机器上。

图示如下:

③在wsB上做些修改,并提交

  1. $ git add .
  2. $ git commit -m "submit on wsB(third)"
  3. [master de9ed05] submit on wsB(third)
  4. 1 files changed, 1 insertions(+), 0 deletions(-)

图示如下:

④把wsB上master分支的内容提交到中央库中。

  1. $ git push
  2. Counting objects: 8, done.
  3. Compressing objects: 100% (2/2), done.
  4. Writing objects: 100% (6/6), 493 bytes, done.
  5. Total 6 (delta 0), reused 0 (delta 0)
  6. Unpacking objects: 100% (6/6), done.
  7. To /home/greta/GitTest/Center/.git/
  8. 20f3246..de9ed05  master -> master

图示如下:

中央库的变化图示请参照 1.中央库-->②wsB第一次推送后,中央库的变化

4.工作站C的操作

①克隆中央库到本机 

  1. $ git clone /home/greta/GitTest/Center/.git/ wsC
  2. Cloning into wsC...
  3. done.

图示如下:

②在wsC上新建一个branch testC并把testC推送到中央库

  1. $ git checkout -b testC
  2. Switched to a new branch 'testC'
  3. $ git add .
  4. $ git commit -m "submit on wsC(Fourth)"
  5. $ git push origin testC
  6. Counting objects: 5, done.
  7. Writing objects: 100% (3/3), 274 bytes, done.
  8. Total 3 (delta 0), reused 0 (delta 0)
  9. Unpacking objects: 100% (3/3), done.
  10. To /home/greta/GitTest/Center/.git/
  11. * [new branch]      testC -> testC

图示如下:

中央库的图示请参见:1.中央库--->③wsC推送后,中央库的变化

5.wsC推送后wsA上操作

①同步wsA与中央库

  1. $ git fetch  
  2. remote: Counting objects: 8, done.  
  3. remote: Compressing objects: 100% (2/2), done.  
  4. remote: Total 6 (delta 0), reused 0 (delta 0)  
  5. Unpacking objects: 100% (6/6), done.  
  6. From /home/greta/GitTest/Center/  
  7.    20f3246..de9ed05  master     -> origin/master  
  8.  * [new branch]      testC      -> origin/testC  

图示如下:

②合并 wsA上master与中央库的master,删除分支testA, 在中央库master的基础上提交

  1. $ git checkout master  
  2. Previous HEAD position was e3e1972... submit on wsC(Fourth)  
  3. Switched to branch 'master'  
  4. Your branch is behind 'origin/master' by 2 commits, and can be fast-forwarded.  
  5. $ git merge origin master  
  6. Fast-forwarding to: origin  
  7. Already up-to-date with master  
  8. Merge made by octopus.  
  9.  a.txt |    2 ++  
  10.  1 files changed, 2 insertions(+), 0 deletions(-)  
  11. $ git branch -d testA  
  12. Deleted branch testA (was eb0f47b).  
  13. $ git add .  
  14. $ git commit -m "submit on wsA(fifth)"  
  15. [master 52ef8ce] submit on wsA(fifth)  
  16.  1 files changed, 2 insertions(+), 0 deletions(-)  

图示如下:

③推送到中央库

  1. $ git push
  2. Counting objects: 6, done.
  3. Compressing objects: 100% (2/2), done.
  4. Writing objects: 100% (4/4), 447 bytes, done.
  5. Total 4 (delta 0), reused 0 (delta 0)
  6. Unpacking objects: 100% (4/4), done.
  7. To /home/greta/GitTest/Center/.git/
  8. de9ed05..52ef8ce  master -> master

图示如下:

 

wsA推送后,中央库的变化请参照:1.中央库---->  ④wsA推送后,中央库的变化

6.wsA推送后wsB的操作

①同步中央库

  1. $ git fetch
  2. remote: Counting objects: 9, done.
  3. remote: Compressing objects: 100% (3/3), done.
  4. remote: Total 7 (delta 0), reused 0 (delta 0)
  5. Unpacking objects: 100% (7/7), done.
  6. From /home/greta/GitTest/Center/
  7. de9ed05..52ef8ce  master     -> origin/master
  8. * [new branch]      testC      -> origin/testC

图示如下:

②合并34ac4和34ac3两个操作:

  1. $ git merge origin master
  2. Fast-forwarding to: origin
  3. Already up-to-date with master
  4. Merge made by octopus.
  5. a.txt |    2 ++
  6. 1 files changed, 2 insertions(+), 0 deletions(-)
  7. $ git merge origin/testC
  8. Auto-merging a.txt
  9. CONFLICT (content): Merge conflict in a.txt
  10. Automatic merge failed; fix conflicts and then commit the result.
  11. $ git mergetool
  12. $ git commit -m "merge on wsB"
  13. $ git push
  14. Counting objects: 8, done.
  15. Compressing objects: 100% (2/2), done.
  16. Writing objects: 100% (4/4), 472 bytes, done.
  17. Total 4 (delta 0), reused 0 (delta 0)
  18. Unpacking objects: 100% (4/4), done.
  19. To /home/greta/GitTest/Center/.git/
  20. 52ef8ce..bf54de7  master -> master

图示如下:

Git操作流程,基本命令演示的更多相关文章

  1. Git的基本命令介绍

    Git的安装 进入官网下载系统所需要的版本  官网地址:https://git-scm.com/downloads 点击下载按钮官方网站一般会根据操作系统的自动下载所需要的Git版本. 下载完成后,点 ...

  2. Git学习(一)——熟悉git操作流程

    本篇笔记前面都是仔细介绍使用方法,如果想跳过这些直接熟悉怎么使用,跳到最后一个知识点完整流程介绍. git 了解:特点.优点 1.git用户版和服务版整合在一起,任何机器上都安装了两个版本 2.git ...

  3. 相见恨晚的 Git 命令动画演示,一看就懂!

    虽然 Git 是一个强大的工具,但是我觉得大部分人都会同意我说的:它也可以是一个--噩梦!我一直觉得,使用 Git 的时候把操作过程在脑海里视觉化会非常有用:当我执行某个命令的时候,分支之间是如何交互 ...

  4. Git使用- 基本命令

    $ git config --global user.name "Your Name"   全局 name 设置 $ git config --global user.email ...

  5. Git Shell 基本命令(官网脱水版)

    用户信息 当安装完 Git 应该做的第一件事就是设置你的用户名称与邮件地址. 这样做很重要,因为每一个 Git 的提交都会使用这些信息,并且它会写入到你的每一次提交中,不可更改: $ git conf ...

  6. git 的基本命令

    ...git init ...git add ...git commit -m "first commit" ...git remote add origin https://gi ...

  7. Git: 一些基本命令

    1.快速获取远程项目 1) git clone xxx.git // 如:git clone git://git.kernel.org/pub/scm/git/git.git 2) git clone ...

  8. 【Git】基本命令使用

    init: 1 git init 添加远程分支: 1 git remote add <远程主机名>  <远程主机地址url> 例如:git remote add origin  ...

  9. Git之基本命令

    先介绍一下Git: Git是一个分布式的版本控制系统,最初由Linus Torvalds编写,用作Linux内核代码的管理.在推出后,Git在其它项目中也取得了很大成功,尤其是在Ruby社区中.目前, ...

随机推荐

  1. CCF-201509-2-日期计算

    问题描述 试题编号: 201509-2 试题名称: 日期计算 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 给定一个年份y和一个整数d,问这一年的第d天是几月几日? 注意闰年 ...

  2. 大数据学习系列之二 ----- HBase环境搭建(单机)

    引言 在上一篇中搭建了Hadoop的单机环境,这一篇则搭建HBase的单机环境 环境准备 1,服务器选择 阿里云服务器:入门型(按量付费) 操作系统:linux CentOS 6.8 Cpu:1核 内 ...

  3. spring的aop详解

    一.aop术语 1.连接点joinpoint: 程序执行的某个特定位置:如类开始初始化之前.类初始化之后.类某个方法调用前.调用后等.Spring仅支持方法的连接点,即仅能在方法调用前.方法调用后以及 ...

  4. JaveScript简单数据类型(JS知识点归纳二)

    JS中的简单数据类型有五种 : --> string --> number -->boolean --> null -->undefined 数据类型的检测 :typeo ...

  5. 使用.Net Core+EF7 CodeFirst(2)

    上一篇的话,说了下怎么使用EF7 实现 CodeFirst去生成数据库, 其实还有好多问题的,这次一点一点的解决吧,都挺简单,不过零零散散的,, 1.读取配置文件,获得链接字符串 2.使用数据库进行增 ...

  6. x86内存映射

    Contents 1 "Low" memory (< 1 MiB) 1.1 Overview 1.2 BIOS Data Area (BDA) 1.3 Extended BI ...

  7. eclipse点击空白处自动打开项目

    如图 选择上面的 Link with Editor 即可

  8. Struts2框架(3)---Action类的3种书写方式

    Action类的3种书写方式 本文主要写有关写Action类的3种书写方式: (1)第一种 Action可以是POJO (简单模型对象)  不需要继承任何父类 也不需要实现任何接口 (2)实现Acti ...

  9. 《深入理解Java虚拟机:JVM高级特性与最佳实践》【PDF】下载

    <深入理解Java虚拟机:JVM高级特性与最佳实践>[PDF]下载链接: https://u253469.pipipan.com/fs/253469-230062566 内容简介 作为一位 ...

  10. Pycharm配置(一)

    Pycharm作为一款强力的Python IDE,在使用过程中感觉一直找不到全面完整的参考手册,因此决定对官网的Pycharm教程进行简要翻译,与大家分享. 1.准备工作 官网下载 2.如何选择Pyc ...