git fetch从远程分支拉取代码。
fetch常结合merge一起用,git fetch + git merge == git pull
一般要用git fetch+git merge,因为git pull会将代码直接合并,造成冲突等无法知道,fetch代码下来要git diff orgin/xx来看一下差异然后再合并。
普及一下
1.分支概念:
图1.1 分支图
如图1.1所示,当前有2个分支master和dev2,当执行git clone的时候会clone下来远程分支到本地远程分支,并且默认本地分支显示master分支,使用git branche可以看到的本地分支只有master,git branch -r可以看到远程2个分支。当使用git checkout dev2 的时候,就会把本地远程分支加入到本地分支中,使用git branch就可以看到本地有2个分支。
2.FETCH_HEAD概念
指定某个branch在服务器上最新状态。
(1)我们切到 dev2分支 上,git fetch一下,然后看看FETCH_HEAD内容。
$cat .git/FETCH_HEAD
01e8809a7861a55f7a403981f2f1bcd68603e33a branch 'dev2' of https://github.com/Moonergfp/learngit
fb515ac7195a9cf210839a4b4941e1e31c55067d not-for-merge 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行中,dev2就是要默认指定merge的分支。直接git merge就可以merge把origin/dev2到dev2分支上。
(2)切到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分支。
3. 用法
(1)git fetch
具体细节分2步走:
a.创建并更新本 地远程分支。即创建并更新origin/xxx 分支,拉取代码到origin/xxx分支上。b.在FETCH_HEAD中设定当前分支-origin/当前分支对应,如直接到时候git merge就可以将origin/abc合并到abc分支上。
缺点:会拉取当前项目的所有分支的commit。这样没必要,如当前项目有很多人在参与,那么就会有很多分支,那么其他分支的提交也会拉取下来,你得等半天下下来,网速不好就蛋疼了。
$ git fetchremote: Counting objects: 6, done.remote: Compressing objects: 100% (4/4), done.remote: Total 6 (delta 0), reused 0 (delta 0), pack-reused 0Unpacking objects: 100% (6/6), done.From https://github.com/Moonergfp/learngit7c5a386..b008b08 abc -> origin/abcff47932..6f28960 master -> origin/master
(2)git fetch origin
(3)git fetch origin abc只是手动指定了要fetch的remote。
指定远程remote和FETCH_HEAD,并且只拉取该分支的提交。
01e8809a7861a55f7a403981f2f1bcd68603e33a branch 'abc' of https://github.com/Moonergfp/learngit