git fetch 详解

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常用命令 GIT常用命令备忘:http://stormzhang.com/git/2014/01/27/gi...
    新篇章阅读 8,660评论 1 26
  • 1、英国广播电视中心公司《地球脉动》,看点:从南极到北极,从赤道到寒带,从非洲草原到热带雨林,再从荒凉峰顶到深邃大...
    犟心独运阅读 288评论 0 0
  • 一个又一个的节日犹如一颗颗璀璨圆润的明珠!因为宝贵,所以值得人们翘首以待。在一天又一天的等待中,中秋佳节就像...
    简非花儿开阅读 597评论 0 3
  • 在未创建灯光前,使用的是默认灯光。 🗄文档 🗄 泛灯光即灯光:以一点向四周照射,默认为照射无限远;聚光灯:以一点向...
    刘板栗阅读 16,585评论 7 76
  • 一年内20万变100万!先来看看知乎网友的一些回复: 1、挖个坑,埋点土,数个一二三四五 2、我包了三千的红包给我...
    吾聊职场阅读 361评论 0 1