美文网首页git
git fetch 详解

git fetch 详解

作者: 忆飞 | 来源:发表于2017-12-14 15:46 被阅读0次

    git fetch从远程分支拉取代码。

    fetch常结合merge一起用,git fetch + git merge == git pull
    一般要用git fetch+git merge,因为git pull会将代码直接合并,造成冲突等无法知道,fetch代码下来要git diff orgin/xx来看一下差异然后再合并。

    1. FETCH_HEAD概念

    指定某个branch在服务器上最新状态。

    • 我们切到 dev分支 上,git fetch一下,然后看看FETCH_HEAD内容。

    $cat .git/FETCH_HEAD
    01e8809a7861a55f7a403981f2f1bcd68603e33a branch 'dev' of https://github.com/Moonergfp/learngit
    ff47932aba92e0eaec6c75ce8112d2f24d890dab not-for-merge
    branch 'develop' of https://github.com/Moonergfp/learngit
    ff47932aba92e0eaec6c75ce8112d2f24d890dab not-for-merge
    branch 'master' of https://github.com/Moonergfp/learngit

    第一列是版本号,第二列是当前FETCH_HEAD是否将要合并的,第三列是git版本库路径。
    如上3行中,dev就是要默认指定merge的分支。直接git merge就可以merge把origin/dev到dev分支上。

    • 切到master分支fetch看

    ff47932aba92e0eaec6c75ce8112d2f24d890dab branch 'master' of https://github.com/Moonergfp/learngit
    fb515ac7195a9cf210839a4b4941e1e31c55067d not-for-merge
    branch 'dev' of https://github.com/Moonergfp/learngit
    01e8809a7861a55f7a403981f2f1bcd68603e33a not-for-merge
    branch 'dev2' of https://github.com/Moonergfp/learngit
    ff47932aba92e0eaec6c75ce8112d2f24d890dab not-for-merge
    branch 'develop' of https://github.com/Moonergfp/learngit

    可以看到当前要合并的是master分支。

    2. 用法

    • git fetch
      具体细节分2步走:
      a. 创建并更新本 地远程分支。即创建并更新origin/xxx 分支,拉取代码到origin/xxx分支上。
      b. 在FETCH_HEAD中设定当前分支-origin/当前分支对应,如直接到时候git merge就可以将origin/abc合并到abc分支上。

    缺点:会拉取当前项目的所有分支的commit。这样没必要,如当前项目有很多人在参与,那么就会有很多分支,那么其他分支的提交也会拉取下来,你得等半天下下来,网速不好就蛋疼了。

    $ git fetch
    remote: Counting objects: 6, done.
    remote: Compressing objects: 100% (4/4), done.
    remote: Total 6 (delta 0), reused 0 (delta 0), pack-reused 0
    Unpacking objects: 100% (6/6), done.
    From https://github.com/Moonergfp/learngit
    7c5a386..b008b08 abc -> origin/abc
    ff47932..6f28960 master -> origin/master

    • git fetch origin
      只是手动指定了要fetch的remote。

    • git fetch origin branch1
      设定当前分支的 FETCH_HEAD' 为远程服务器的branch1分支`.

      注意: 在这种情况下, 不会在本地创建本地远程分支, 这是因为:

      这个操作是git pull origin branch1的第一步, 而对应的pull操作,并不会在本地创建新的branch.

      一个附加效果是:

      这个命令可以用来测试远程主机的远程分支branch1是否存在, 如果存在, 返回0, 如果不存在, 返回128, 抛出一个异常.

    • git fetch origin branch1:branch2
      只要明白了上面的含义, 这个就很简单了,
      首先执行上面的fetch操作
      使用远程branch1分支在本地创建branch2(但不会切换到该分支),
      如果本地不存在branch2分支, 则会自动创建一个新的branch2分支,
      如果本地存在branch2分支, 并且是`fast forward', 则自动合并两个分支, 否则, 会阻止以上操作.

    • git fetch origin :branch2
      等价于: git fetch origin master:branch2

    相关文章

      网友评论

        本文标题:git fetch 详解

        本文链接:https://www.haomeiwen.com/subject/peukwxtx.html