git(三) git fetch 妙用

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
       
 











  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值