(转)git rebase 命令

转自:http://blog.csdn.net/hudashi/article/details/7664631/

原文:

http://gitbook.liuhui998.com/4_2.html

一、基本

git rebase用于把一个分支的修改合并到当前分支。

假设你现在基于远程分支"origin",创建一个叫"mywork"的分支。

$ git checkout -b mywork origin

假设远程分支"origin"已经有了2个提交,如图

现在我们在这个分支做一些修改,然后生成两个提交(commit).

$ vi file.txt

$ git commit

$ vi otherfile.txt

$ git commit

...

但是与此同时,有些人也在"origin"分支上做了一些修改并且做了提交了. 这就意味着"origin"和"mywork"这两个分支各自"前进"了,它们之间"分叉"了。

在这里,你可以用"pull"命令把"origin"分支上的修改拉下来并且和你的修改合并; 结果看起来就像一个新的"合并的提交"(merge commit):

但是,如果你想让"mywork"分支历史看起来像没有经过任何合并一样,你也许可以用 git rebase:

$ git checkout mywork

$ git rebase origin

这些命令会把你的"mywork"分支里的每个提交(commit)取消掉,并且把它们临时 保存为补丁(patch)(这些补丁放到".git/rebase"目录中),然后把"mywork"分支更新 为最新的"origin"分支,最后把保存的这些补丁应用到"mywork"分支上。

当‘mywork‘分支更新之后,它会指向这些新创建的提交(commit),而那些老的提交会被丢弃。 如果运行垃圾收集命令(pruning garbage collection), 这些被丢弃的提交就会删除. (请查看 git gc)

二、解决冲突

在rebase的过程中,也许会出现冲突(conflict). 在这种情况,Git会停止rebase并会让你去解决 冲突;在解决完冲突后,用"git-add"命令去更新这些内容的索引(index), 然后,你无需执行 git-commit,只要执行:

$ git rebase --continue

这样git会继续应用(apply)余下的补丁。

在任何时候,你可以用--abort参数来终止rebase的行动,并且"mywork" 分支会回到rebase开始前的状态。

$ git rebase --abort

三、git rebase和git merge的区别

现在我们可以看一下用合并(merge)和用rebase所产生的历史的区别:

当我们使用Git log来参看commit时,其commit的顺序也有所不同。

假设C3提交于9:00AM,C5提交于10:00AM,C4提交于11:00AM,C6提交于12:00AM,

对于使用git merge来合并所看到的commit的顺序(从新到旧)是:C7 ,C6,C4,C5,C3,C2,C1

对于使用git rebase来合并所看到的commit的顺序(从新到旧)是:C7 ,C6‘,C5‘,C4,C3,C2,C1

因为C6‘提交只是C6提交的克隆,C5‘提交只是C5提交的克隆,

从用户的角度看使用git rebase来合并后所看到的commit的顺序(从新到旧)是:C7 ,C6,C5,C4,C3,C2,C1

另外,我们在使用git pull命令的时候,可以使用--rebase参数,即git pull --rebase,这里表示把你的本地当前分支里的每个提交(commit)取消掉,并且把它们临时 保存为补丁(patch)(这些补丁放到".git/rebase"目录中),然后把本地当前分支更新 为最新的"origin"分支,最后把保存的这些补丁应用到本地当前分支上。关于git pull的更多内容请参考《git pull简介

时间: 2024-08-26 23:12:56

(转)git rebase 命令的相关文章

Git rebase命令实战

一.前言 一句话,git rebase 可以帮助项目中的提交历史干净整洁!!! 二.避免合并出现分叉现象 git merge操作 1.新建一个 develop 分支 2.在develop分支上新建两个文件 3.然后分别执行 add.commit.push 4.接着切换到master分支 分别添加c. 原文地址:https://www.cnblogs.com/wdyff/p/9749835.html

Git rebase命令实战fdggggf

https://baobao.baidu.com/article/9280c57a40d7b5260729b8f32ce2b665.htmlhttps://baobao.baidu.com/article/9280c57a40d7b5260729b8f32ce2b665.htmlhttps://baobao.baidu.com/article/9280c57a40d7b5260729b8f32ce2b665.htmlhttps://baobao.baidu.com/article/9280c57

git rebase使用

git rebase在<git权威指南>一书中被翻译为变基,听着有些别扭吧,变基变基,变成库克了,在<pro git>中被翻译成衍合,所以以后git rebase均使用<pro git>中的翻译方式. 在git中将个分支中的修改整合到另一个分支的办法有两种:merge和rebase,现在又如下使用情景,在master分支的第3次提交产生一个分支dev,在这个dev分支上做了两次提交,而此时master分支由于某些原因又进行了两次提交,现在需要将dev分支和master分

聊下 git rebase -i

在使用git开发的时候经常会面临一个常见的问题.多个commit 需要合并为一个完整的commit提交. 我们先说第一个合并多个commit为一个完整的commit 我先基于develop主分支拉出一个功能分支(每个人和每个公司对分支的管理都不太一样,这里不需要太纠结.).这里的develop是开发主分支,所有的开发功能代码都需要回归到这个develop分支中去. git branch -a –vv develop_fixbug_imageprint 分支是我基于远程develop分支拉出来的开

git rebase(高级)

原文:http://gitbook.liuhui998.com/4_3.html 一.基本 对于 git rebase ,你亦可以选择进行交互式的rebase.这种方法通常用于在向别处推送提交之前对它们进行重写.交互式rebase提供了一个简单易用的途径让你在和别人分享提交之前对你的提交进行分割.合并或者重排序.在把从其他开发者处拉取的提交应用到本地时,你也可以使用交互式rebase对它们进行清理. 如果你想在rebase的过程中对一部分提交进行修改,你可以在' git rebase '命令中加

git fetch 命令

git fetch命令用于从另一个存储库下载对象和引用. 使用语法 git fetch [<options>] [<repository> [<refspec>-]] git fetch [<options>] <group> git fetch --multiple [<options>] [(<repository> | <group>)-] git fetch --all [<options>

git分支切换与git rebase , git stash

今天在dev分支开发直播的其他功能,老大突然发消息说在master分支修改一下网站文章的样式,因此发生了对git的一些了解. 正在dev分支开发,那么dev分支开发的东西怎么办呢,这就要用的git的存储功能的,git stash向堆栈推送一个新的储藏,只要运行git stash这就要用的git的存储功能的 1 $ git stash 2 Saved working directory and index state WIP on dev: 3b1687c 房间加载更多 3 HEAD is now

git rebase简介(高级篇)

原文:http://gitbook.liuhui998.com/4_3.html 一.基本 对于git rebase,你亦可以选择进行交互式的rebase.这种方法通常用于在向别处推送提交之前对它们进行重写.交互式rebase提供了一个简单易用的途径让你在和别人分享提交之前对你的提交进行分割.合并或者重排序.在把从其他开发者处拉取的提交应用到本地时,你也可以使用交互式rebase对它们进行清理. 如果你想在rebase的过程中对一部分提交进行修改,你可以在'git rebase'命令中加入'-i

通过git rebase修改commit message

今天发现一个项目的git commit message中的单词拼错了,需要修改一下.但这样简单的修改,需要通过git rebase才能完成. 首先要git rebase到需要修改message的那个commit的前1个commit.假设commit id是32e0a87f,运行下面的git rebase命令: git rebase -i 32e0a87f 在git bash中运行上面的命令后,会弹出编辑框,在编辑框中会分行依次显示以pick开头的这个commit之后的所有commit messa