一、前言

  一句话,git rebase 可以帮助项目中的提交历史干净整洁!!!

二、避免合并出现分叉现象

git merge操作

  1、新建一个 develop 分支

  

   2、在develop分支上新建两个文件

  

  3、然后分别执行 add、commit、push

  

   4、接着切换到master分支

  分别添加c.txt 和 d.txt两个文件,分别进行add、commit、push

  

  5、现在想把develop分支上开发的部分合并到master分支上

  

  6、git merge 会将master和develop合并的过程通过如下形式展示出来。

  借助 gitk 命令

  

  借助sourceTree工具

  

git rebase操作

  如果master和develop分支上的这些开发部分都是同一个人操作,在合并的时候不想产生这种分叉的结果,怎么办呢?

  git-rebase命令简介:用在从上游分支获取最新commit信息,并有机的将当前分支和上游分支进行合并。因为develop分支是在master分支基础上建立的,所以master称为topic的上游分支。

  1、首先通过 git reset 恢复到master合并之前的状态

  2、切换到develop分支,执行如下操作

  

  

   3、如果你想把 rebase 之后的 master 分支推送到远程仓库,Git 会阻止你这么做,因为两个分支包含冲突。但你可以传入 –force 标记来强行推送。

  

  4、查看一下develop分支合并的效果,如下。

  

  

  看一下rebase的结果,就像是develop先把自己的提交保存起来,然后将master中的提交合并过来,最后在加上自身分支的提交,这样就不存在分支的合并效果了。

  5、接着切换到master分支,执行git merge 操作就可以了

  

  

  这时候,master和develop分支已经同步了。

其他异常情况

  在rebase的过程中,也许会出现冲突(conflict). 在这种情况,Git会停止rebase并会让你去解决 冲突;在解决完冲突后,用"git-add"命令去更新这些内容的索引(index),然后你无需执行 git-commit,只要执行 git rebase --continue。这样git会继续应用(apply)余下的补丁。在任何时候,你可以用--abort参数来终止rebase的行动,并且"mywork" 分支会回到rebase开始前的状态。即git rebase --abort。

手动合并多个commit记录

rebase -i 命令介绍

  git rebase -i [startpoint] [endpoint]

  其中-i的意思是--interactive,即弹出交互式的界面让用户编辑完成合并操作,[startpoint] [endpoint]则指定了一个编辑区间,如果不指定[endpoint],则该区间的终点默认是当前分支HEAD所指向的commit(注:该区间指定的是一个前开后闭的区间)。
在查看到了log日志后,我们运行以下命令:
  git rebase -i 0bb85c 582db9
  或者
  git rebase -i HEAD~3

  

  上面未被注释的部分列出的是我们本次rebase操作包含的所有提交,下面注释部分是git为我们提供的命令说明。每一个commit id 前面的pick表示指令类型,git 为我们提供了以下几个命令:

  pick:保留该commit(缩写:p)
  reword:保留该commit,但我需要修改该commit的注释(缩写:r)
  edit:保留该commit, 但我要停下来修改该提交(不仅仅修改注释)(缩写:e)
  squash:将该commit和前一个commit合并(缩写:s)
  fixup:将该commit和前一个commit合并,但我不要保留该提交的注释信息(缩写:f)
  exec:执行shell命令(缩写:x)
  drop:我要丢弃该commit(缩写:d)

rebase -i命令执行

  1、git rebase -i HEAD~3

    2、编辑合并信息

  

    3、修改commit信息

  

  4、commit信息预览

  

  5、commit合并结果

  

   6、可以看到master上之后又1条提交记录了,而develop上还有3个提交记录

  

  还是要通过 git push -f 命令将合并的commit结果提交的远程仓库中。

  如果develop分支也想要变成master分支这种合并效果,记住不要使用git merge 命令,还时会出现分叉的情况。继续使用 git rebase master命令。

  

自动合并多个commit记录

命令介绍

  git commit –fixup 自动在commit消息前添加fixup!关键字。

  git rebase -i –autosquash 使用rebase自动合并被标记为fixup!的commit,其实是根据sha值来的。

命令操作

  1.继续修复如下图所示对应的bug

  

  2、修改完之后执行 git commit --fixup 需要合并的commit id

  

  3、commit fixup 之后的效果

  

  4、执行git rebase -i --autosquash 需要合并commit id的父级commit id

    或者

    git rebase -i --autosquash commit id^

  

  5、执行rebase autosquash结果

  

Git rebase命令实战的更多相关文章

  1. (转)git rebase 命令

    转自:http://blog.csdn.net/hudashi/article/details/7664631/ 原文: http://gitbook.liuhui998.com/4_2.html 一 ...

  2. git rebase命令

    使用git rebase合并多次commit. 当年提交代码后,管理员发现,你的代码不能提交到服务器上,注意原因在于,你的commit中的commit和服务器中的有些commit不在同一时间轴上,即: ...

  3. Git小技巧之使用Rebase命令合并提交

    想要获取更多文章可以访问我的博客 - 代码无止境. 在日常的开发过程中,我们一个功能可能会有很多次提交.而且我们公司的开发是不允许直接往公司仓库提交代码,所以需要fork到自己的仓库然后merge过去 ...

  4. git rebase 的使用

    rebase 在 Git 中整合来自不同分支的修改主要有两种方法:merge 以及 rebase. 在本节中我们将学习什么是“rebase”,怎样使用“rebase”,并将展示该操作的惊艳之处,以及指 ...

  5. Git rebase的使用

    rebase 在 Git 中整合来自不同分支的修改主要有两种方法:merge 以及 rebase. 在本节中我们将学习什么是“rebase”,怎样使用“rebase”,并将展示该操作的惊艳之处,以及指 ...

  6. 聊下 git rebase -i

    在使用git作为源代码管理工具的时候,开发的时经常会面临一个常见的问题,多个commit 需要合并为一个完整的commit提交. 在一个基本的迭代周期里,你会有很多次commit,有跟配置文件相关的, ...

  7. git rebase简介(高级篇)

    原文:http://gitbook.liuhui998.com/4_3.html 一.基本   对于git rebase,你亦可以选择进行交互式的rebase.这种方法通常用于在向别处推送提交之前对它 ...

  8. 通过git rebase修改commit message

    今天发现一个项目的git commit message中的单词拼错了,需要修改一下.但这样简单的修改,需要通过git rebase才能完成. 首先要git rebase到需要修改message的那个c ...

  9. 分布式版本管理工具 git常用命令

    Git global setup git config --global user.name "joey" git config --global user.email " ...

随机推荐

  1. Swift DispatchQueue

    延迟2s执行 DispatchQueue.main.asyncAfter(deadline: DispatchTime.now()+2)

  2. 前端html

    前端html html   是一种描述网页的语言,是超文本标记语言 :hyper Text Markup Lauguage 是一种标记语言[标记语言是一套标记标签 markup tag]使用标记标签来 ...

  3. es6简单介绍

    1.ECMAScript 6 简介 2.let和const命令 3.变量的解构赋值 4.字符串的扩展之模板字符串 5.正则的扩展 6.数值的扩展 7.函数的扩展 8.数组的扩展 9.对象的扩展 10. ...

  4. ActiveMQ消息的消费原理

    消费端消费消息: 在 初识ActiveMQ 中我提到过,两种方法可以接收消息,一种是使用同步阻塞的ActiveMQMessageConsumer#receive方法.另一种是使用消息监听器Messag ...

  5. LeetCode(109):有序链表转换二叉搜索树

    Medium! 题目描述: 给定一个单链表,其中的元素按升序排序,将其转换为高度平衡的二叉搜索树. 本题中,一个高度平衡二叉树是指一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1. 示例: ...

  6. java----Java的栈,堆,代码,静态存储区的存储顺序和位置

    转载:https://blog.csdn.net/zhangbaoanhadoop/article/details/82193497

  7. hdu1565 用搜索代替枚举找可能状态或者轮廓线解(较优),参考poj2411

    这题用直接枚举是超时的,必须要用搜索来搜索出所有可能的状态,然后再进行枚举 这是较慢的做法 /* 方格取数,相邻格子的数不可取,问最多取到的和是什么 有点类似炮兵布阵,先打出所有可能的状态,然后dp[ ...

  8. P0505

      算法训练 P0505   时间限制:1.0s   内存限制:256.0MB      一个整数n的阶乘可以写成n!,它表示从1到n这n个整数的乘积.阶乘的增长速度非常快,例如,13!就已经比较大了 ...

  9. python pip install mysql-python报错

    报错: 下载地址: https://www.lfd.uci.edu/~gohlke/pythonlibs/#mysql-python

  10. 配置frp

    一.下载 下载地址:https://github.com/fatedier/frp/releases 下载linux_amd64的,如果是32位系统就下载linux_386 二.安装 有公网IP的服务 ...