git rebase超详细解读,一文搞懂

1. Git Rebase的介绍

我们都知道,git rebase可以实现git节点或者分支的合并,但是,真正涉及到为什么要使用git rebase,它的好处又是什么等一些比较实际的问题,很多同学就搞不清楚了,本文聚焦于git rebase,着重讨论该命令的两种妙用,来帮助大家直观的理解这条命令。

写在前面:如果你的分支不只有你在进行开发,那么git-rebase可能会导致提交记录的丢失,但是如果你是在自己的分支上进行开发,那么这无疑是一个很棒的选择。

2. Git Rebase作用一:合并本地的多条提交(commit)记录

一般情况下,我们进行开发时,都是从master分支拉一个自己的开发分支,进行代码修改操作,再git add以及git commit之后将我们修改好的代码git push到远程仓库。

但是,很多情况下,我们并不会仅仅在本地git commit一次,而是会执行很多次,而我们知道,每一个的git commit都会形成一个git节点,而如果我们把这些节点都push到远端,就会使项目的git日志很乱,因为你的这些commit对于其他同学来说都仅仅是为了完成你对应的修改工作,他们希望的是,你能在一次commit操作中把你的修改全部完成,这时,就可以用到我们的git rebase操作了,在git push之前,我们可以将几次本地的commit操作合并,这样,我们推送到远端的commit操作就只有一个了,更利于项目管理。

已经在本地提交了两次:

调用git rebase命令合并本地的commit节点

git rebase -i HEAD~2
复制代码

经过上面的操作,我们就只剩了一个commit节点,里面包含了我们所有的修改信息,再合并到master中。就不会有开始提到的问题了。

需要注意的是,如果你的commit已经push到远端了,那么就没有办法使用我们的这个技巧了。

2. Git Rebase作用一:分支合并

1.我们先从 master 分支切出一个 dev 分支,进行开发:

git checkout -b feature1
复制代码

  1. 其他同学完成了一次 hotfix,并合并入了 master 分支,此时 master 已经领先于你的 feature1 分支了:

  1. 使用 rebase 来同步其他同学修改的结果,来保证自己的代码是最新的版本

3. Git Rebase的过程

git rebase 做了什么操作呢?

首先,git 会把 feature1 分支里面的每个 commit 取消掉;
其次,把上面的操作临时保存成 patch 文件,存在 .git/rebase 目录下;
然后,把 feature1 分支更新到最新的 master 分支;
最后,把上面保存的 patch 文件应用到 feature1 分支上。

4. 冲突解决

在 rebase 的过程中,也许会出现冲突 conflict。在这种情况,git 会停止 rebase 并会让你去解决冲突。在解决完冲突后,用 git add 命令去更新这些内容。

注意,你无需执行 git-commit,只要执行 continue

git rebase --continue
复制代码

这样 git 会继续应用余下的 patch 补丁文件。

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

git rebase —abort
复制代码

5. 注意事项

根据上文来看,git-rebase 很完美,解决了我们的两个问题:
1.合并 commit 记录,保持分支整洁;
2.相比 merge 来说会减少分支合并的记录;

但是如果你的分支不只有你在进行开发,那么git-rebase可能会导致提交记录的丢失。

那么当他 pull 远程 master 的时候,就会有丢失提交纪录。这就是为什么我们经常听到有人说 git rebase 是一个危险命令,因为它改变了历史,我们应该谨慎使用。

但是,只要你自己的分支上需要 rebase 的所有 commits 历史还没有被 push 过,就可以安全地使用 git-rebase来操作。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: git rebase 命令可以用于将一个分支的修改合并到另一个分支上。具体的参数选项包括: 1. `--onto`: 将原来分支上的一段提交,移动到另一个分支上。语法为 `git rebase --onto <目标分支> <原始分支> <终止提交>`。例如,将 feature 分支上从 commit1 到 commit3 的提交移到 master 分支上:`git rebase --onto master feature commit1~3` 2. `--interactive` 或 `-i`: 允许交互式的 rebase 操作,可以对提交进行编辑、删除、修改等操作。语法为 `git rebase -i <终止提交>`。例如,编辑最近 5 个提交:`git rebase -i HEAD~5` 3. `--continue` 或 `-c`: 在解决冲突后,继续执行 rebase 操作。语法为 `git rebase --continue`。例如,解决完冲突后继续执行 rebase:`git rebase --continue` 4. `--abort`: 取消当前正在执行的 rebase 操作。语法为 `git rebase --abort`。例如,取消当前正在执行的 rebase:`git rebase --abort` 下面是一些示例: 1. 将 feature 分支上从 commit1 到 commit3 的提交移到 master 分支上: `git rebase --onto master feature commit1~3` 2. 编辑最近 5 个提交: `git rebase -i HEAD~5` 3. 解决完冲突后继续执行 rebase: `git rebase --continue` 4. 取消当前正在执行的 rebase: `git rebase --abort` ### 回答2: git rebaseGit中的一个命令,用于将一个分支中的提交添加到另一个分支的末尾。它可以用于合并分支或者修改提交记录。 git rebase命令的参数选项有以下几个: 1. --onto:指定重演提交操作开始的基础提交。可以使用这个选项将一个分支的部分提交移动到另一个分支上,比如`git rebase --onto master develop feature`将feature分支中从develop分支分叉点开始的提交移动到master分支。 2. -i/--interactive:进入交互模式,可以编辑提交记录。使用这个选项可以修改提交记录、合并或删除提交,以达到想要的提交历史。 3. -m/--onto:在合并过程中,对于多个父提交,指定哪个提交应该用作重演的基础。这个选项可以用来解决分支合并时的冲突。 4. --ignore-date:在重演提交时,忽略提交的时间戳,将它们全部设置为当前时间。 下面是一些git rebase命令的示例: 1. `git rebase develop`:将当前分支的提交重演到develop分支的最新提交之后。 2. `git rebase --onto master develop feature`:将feature分支中从develop分支分叉点开始的提交重演到master分支之上。 3. `git rebase -i HEAD~5`:进入交互模式,对当前分支的最近5个提交进行编辑。 4. `git rebase -m`:在合并父提交时,指定使用多个父提交中的第一个作为基础。 5. `git rebase --ignore-date`:将当前分支的提交重演到目标分支上,并把所有提交的时间戳设置为当前时间。 以上是git rebase命令的参数选项以及示例的详细介绍。使用这些选项可以更灵活地使用git rebase命令来管理分支和修改提交记录。 ### 回答3: git rebaseGit 提供的一个强大的命令,用于将一个分支上的提交修改应用到另一个分支上。它有几个常用的参数选项,下面详细介绍一下这些选项及其示例: 1. --onto:此选项允许你重新设置一个新的基准分支,将其设置为想要修改应用的目标分支。示例:git rebase --onto master dev1 dev2,表示将 dev1 分支到 dev2 分支之间的提交应用到 master 分支上。 2. --interactive 或 -i:该选项允许你以交互方式重新排列、编辑、删除、合并提交。示例:git rebase -i HEAD~3,表示将当前分支的最新 3 个提交显示在交互式界面上,你可以进行相关操作。 3. --continue:用于在解决冲突后,继续应用之前中断的 rebase 操作。示例:git rebase --continue,表示继续之前被中断的 rebase 操作。 4. --skip:在解决冲突后,使用该选项来跳过当前的提交,继续应用之后的提交。示例:git rebase --skip,表示跳过当前提交,继续应用其他提交。 5. --abort:用于取消之前的 rebase 操作,恢复到 rebase 之前的状态。示例:git rebase --abort,表示放弃当前正在进行的 rebase 操作,恢复到 rebase 之前的状态。 以上是 git rebase 命令的一些常用参数选项及其示例,这些选项能够帮助开发者更灵活地管理和应用提交修改,提高工作效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值