有问题为什么不问问神奇的 man 呢?

rebase 也算是我比较常用的一个指令了,但是很长时间以来,对这个指令的认识还是不够深刻,于是就找了个时间认真地读了一下 git rebase 的文档。这份文档不需要在网络上查找,在自己的电脑上直接使用 man git-rebase 就可以查看了。在这份文档中,被提到的几个重要的 rebase 参数就是 newbaseupstreambranch。除此之外,-i 也是一个能够极大的提升使用体验的选项,允许我们交互式的选取需要操作的提交。

git rebase [-i | --interactive] [<options>] [--exec <cmd>] [--onto <newbase>]
[<upstream> [<branch>]]

三个参数

在执行 git rebase 的之前,如果我们指定了 branch 这个参数,那么 git 会在开始 rebase 操作之前签出到 branch

接着,git 会把所有在当前分支但不在 upstream 分支的提交保存到一个临时区域。如果想要在 rebase 开始之前了解哪些提交会被移到临时区域,可以使用 git log <upstream>..<branch> 查看。

然后,如果我们设置了 newbase,那么 git 会把当前分支重置到 newbase ,否则,就重置到 upstream ,这里的效果就相当于 git reset <newbase>

接下来,git 会将之前存放到临时区域内的提交逐个按顺序地重新作用到当前分支上。

根据上面介绍的执行过程,我们可以总结出以下几个知识点:

  1. branch 分支或者执行 git rebase 的当前分支,最终会被移动到 upstream 或者 newbase 分支上

  2. branch 与 upstream 构成了一个选择器,可以通过这两个参数来把 branch..upstream 之间的提交移动跟随 branch 移动到新的地方

这样看来,rebase 做的事其实是使用 upstream 以及 branch 选取一段提交,然后在把这段提交从原先的分支上剪下来,然后嫁接到 upstream 或者 newbase 上去。

接着结合一个简单的例子来熟悉一下 rebase 中这三个参数的作用,例如,我们有这样一个仓库:

  A---B<start>---C---D<feature><HEAD>
/
E---F---G<master>

我们目前位于 feature 分支,现在我们需要使用 rebase 将 feature 分支上的 C、D 两个提交移植到 master 上面。因为最终的目的地是 master 分支,所以可以确定 newbase 参数的值是 master;为了选中 C、D 两个提交,我们可以使用 feature 分支作为 branch 参数,使用 start 分支作为 upstream 参数。最终,我们需要执行的指令就是:

git rebase --onto master start feature

因为,我们目前就在 feature 上面,所以 branch 参数可以省略掉:

git rebase --onto master start

最终我们得到的结果如下所示:

          C'---D'<feature><HEAD>
/
E---F---G
\
A---B<start>

交互式操作后可能会遇到的问题

在交互式 rebase 中,我们可以选取需要操作的提交,但这种可选择的操作有时候可能会给 git 新手造成一种令人慌乱的局面。例如,我们有这样一个仓库:

  A---B---C---D<feature><HEAD>
/
D---E---F<master>

然后,我们执行下面的命令:

git rebase -i master

假设只有 B、C 被选取了,那么这个仓库接下来就会变成:

          B'---C'<feature>
/
D---E---F<master>

现在,你可能已经发现了一个问题,A 与 D 这两个提交“消失”了,这时候先不要慌,可以先想想办法研究出时光机器回到过去阻止自己。当然,这只是一个玩笑。这两个提交并没有真正的消失,他们只是没有被某个分支引用而已。要让它们重新回到分支树上,我们需要先查询这两个提交的 hash :

git reflog feature

reflog 可以帮助我们查看指定分支的操作历史,包括 commit、rebase 等操作。

查询到 hash 之后,只要在这些被历史遗忘的 commit 上创建新的分支,我们就可以在 git log 中重新见到他们了。

学习 Git Rebase的更多相关文章

  1. 使用git Rebase让历史变得清晰

    当多人协作开发一个分支时,历史记录通常如下方左图所示,比较凌乱.如果希望能像右图那样呈线性提交,就需要学习git rebase的用法. “Merge branch”提交的产生 我们的工作流程是:修改代 ...

  2. git 学习(4) ----- git rebase

    使用git rebase 的前提是多人协作下的分支开发,如果是单人开发,那就没有必要使用它了,这是由git rebase 的作用所决定的,git rebase 有两大作用:一个是与主分支保持同步,一个 ...

  3. Gitlab+Jenkins学习之路(五)之git merge和git rebase的区别

    命令行测试 [root@linux-node1 ~]# mkdir testing [root@linux-node1 ~]# [root@linux-node1 ~]# cd testing/ [r ...

  4. git 学习笔记 --- Rebase

    在上一节我们看到了,多人在同一个分支上协作时,很容易出现冲突.即使没有冲突,后push的童鞋不得不先pull,在本地合并,然后才能push成功. 每次合并再push后,分支变成了这样: $ git l ...

  5. 深入理解学习Git工作流

    http://blog.csdn.net/hongchangfirst/article/list/3 //可以看看 http://blog.csdn.net/hongchangfirst/articl ...

  6. [转]深入理解学习GIT工作流

    深入理解学习Git工作流 字数13437 阅读2761 评论3 喜欢70 个人在学习git工作流的过程中,从原有的 SVN 模式很难完全理解git的协作模式,直到有一天我看到了下面的文章,好多遗留在心 ...

  7. 菜鸟学习 git

    到新公司学习和使用 git 有一段时间了.不得不说 git 真的很牛逼,当然,git 的牛逼是建立在 Linux 之父的牛逼的基础上的. 首先跪着推荐 git 学习网站:http://www.liao ...

  8. 深入理解学习Git工作流(转)

    个人在学习git工作流的过程中,从原有的 SVN 模式很难完全理解git的协作模式,直到有一天我看到了下面的文章,好多遗留在心中的困惑迎刃而解,于是我将这部分资料进行整理放到了github上,欢迎st ...

  9. git rebase和git merge的用法

    http://softlab.sdut.edu.cn/blog/subaochen/2016/01/git-rebase%E5%92%8Cgit-merge%E7%9A%84%E7%94%A8%E6% ...

随机推荐

  1. 数据分析 - pandas

    简介 pandas是一个强大的Python数据分析的工具包,它是基于Numpy构建的,正因pandas的出现,让Python语言也成为使用最广泛而且强大的数据分析环境之一. Pandas的主要功能: ...

  2. (转)虚拟文件系统(VFS)浅析

    http://www.cnblogs.com/zsw-1993/p/5048144.html 在我看来, "虚拟"二字主要有两层含义: 1, 在同一个目录结构中, 可以挂载着若干种 ...

  3. Nim博弈&&POJ1704

    Nim博弈 题目 有n堆物品,两人轮流取,每次取某堆中不少于1个,先取完者胜. 分析 经典问题,该问题的策略也成为了许多问题的基础. 要判断游戏的胜负只需要异或运算就可以了,有以下结论: $a_1 \ ...

  4. 项目(1-2)ES32获取mpu9250传入数据库

    . 报一个错,找不到min函数 #define min(X,Y) ((X) < (Y) ? (X) : (Y)) 手动添加 之后不报错了 .最原始的采集 /******************* ...

  5. 文件搜索命令(命令搜索)which、whereis

    一.which命令: 搜索命令所在目录(绝对路径)或者别名信息. 用户可以使用的命令存放在: /bin /usr/bin 管理员使用的命令: /sbin /usr/sbin 1.带有别名的命令: 二. ...

  6. Harbor基础

    harbor: Harbor是构建企业级私有docker镜像的仓库的开源解决方案,它是Docker Registry的更高级封装,它除了提供友好的Web UI界面,角色和用户权限管理,用户操作审计等功 ...

  7. SpringCloud:搭建基于Gateway的微服务网关(一)

    1.需求 最近在尝试着写一个开放平台,于是先搭建网关. 作用:统一的请求入口,完成对请求的跟踪,限流(未做),鉴权,分发,封装响应 2.工作原理 2.1.请求 在开放平台中申请对接口的使用,申请通过后 ...

  8. Inno setup 判断系统32位还是64位

    [Files] ; Install MyProg-x64.exe -bit mode (x64; see above), ; Check: Is64BitInstallMode 表示是64位windo ...

  9. pymysql装饰器封装

    pymysql装饰器封装 def openClose(fun): def run(sql=None): coon =pymysql.connect(host='localhost' ,port=330 ...

  10. Netty - PooledByteBufAllocator

    堆外内存, 就是非JVM管理的,由os管理的内存,等同于c语言里面的mallco分配的内存 故堆外内存的好处, 1. 不会有GC回收,缓解gc压力 2. 避免一次copy,发生到socket buff ...