美文网首页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