zoukankan      html  css  js  c++  java
  • 使用git Rebase让历史变得清晰

    当多人协作开发一个分支时,历史记录通常如下方左图所示,比较凌乱。如果希望能像右图那样呈线性提交,就需要学习git rebase的用法。

    “Merge branch”提交的产生

    我们的工作流程是:修改代码→提交到本地仓库→拉取远程改动→推送。正是在git pull这一步产生的Merge branch提交。事实上,git pull等效于get fetch origin和get merge origin/master这两条命令,前者是拉取远程仓库到本地临时库,后者是将临时库中的改动合并到本地分支中。

    要避免Merge branch提交也有一个“土法”:先pull、再commit、最后push。不过万一commit和push之间远程又发生了改动,还需要再pull一次,就又会产生Merge branch提交。

    使用git pull –rebase

    修改代码→commit→git pull –rebase→git push。也就是将get merge origin/master替换成了git rebase origin/master,它的过程是先将HEAD指向origin/master,然后逐一应用本地的修改,这样就不会产生Merge branch提交了。具体过程见下文扩展阅读。

    使用git rebase是有条件的,你的本地仓库要“足够干净”。可以用git status命令查看当前改动::

    $ git status
    On branch master
    Your branch is up-to-date with 'origin/master'.
    nothing to commit, working directory clean

    本地没有任何未提交的改动,这是最“干净”的。稍差一些的是这样:

    $ git status
    On branch master
    Your branch is up-to-date with 'origin/master'.
    Untracked files:
      (use "git add <file>..." to include in what will be committed)
        test.txt
    nothing added to commit but untracked files present (use "git add" to track)

    即本地只有新增文件未提交,没有改动文件。我们应该尽量保持本地仓库的“整洁”,这样才能顺利使用git rebase。特殊情况下也可以用git stash来解决问题,有兴趣的可自行搜索。

    修改git pull的默认行为

    每次都加–rebase似乎有些麻烦,我们可以指定某个分支在执行git pull时默认采用rebase方式:

    $ git config branch.master.rebase true

    如果你觉得所有的分支都应该用rebase,那就设置:

    $ git config --global branch.autosetuprebase always

    这样对于新建的分支都会设定上面的rebase=true了。已经创建好的分支还是需要手动配置的。

    扩展阅读[1]:git rebase工作原理

    先看看git merge的示意图:

    图片来源

    可以看到Some Feature分支的两个提交通过一个新的提交(蓝色)和master连接起来了。

    再来看git rebase的示意图:

    Feature分支中的两个提交被“嫁接”到了Master分支的头部,或者说Feature分支的“基”(base)变成了 Master,rebase也因此得名。

    扩展阅读[2]:git merge –no-ff

    在做项目开发时会用到分支,合并时采用以下步骤:

    $ git checkout feature-branch
    $ git rebase master
    $ git checkout master
    $ git merge --no-ff feature-branch
    $ git push origin master

    历史就成了这样:

    可以看到,Merge branch ‘feature-branch'那段可以很好的展现出这些提交是属于某一特性的。

  • 相关阅读:
    Spring中bean的scope详解
    【转】Servlet生命周期
    layui切换子页面销毁定时器,切换页面失效
    工具记录 [部分摘抄 , 持续更新记录中]
    常用js对dom操作的分装[摘抄记录中....]
    常用js函数的封装集合,更新中...
    360安全浏览器的兼容显示页面
    关于浏览器弹出拦截窗口
    电脑连接小米盒子测试App记录
    面试 & 学习网址记录
  • 原文地址:https://www.cnblogs.com/UnGeek/p/5737653.html
Copyright © 2011-2022 走看看