您的位置:首页 > Web前端

git(三) git fetch 妙用

2015-11-06 02:32 357 查看
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 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

(2)git fetch origin

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

(3)git fetch origin abc
        指定远程remote和FETCH_HEAD,并且只拉取该分支的提交。
01e8809a7861a55f7a403981f2f1bcd68603e33a branch 'abc' of https://github.com/Moonergfp/learngit        
 
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: