git fetch和git pull之间的区别

转载 2018年04月17日 10:19:47

git fetch和git pull都可以用来更新本地库,它们之间有什么区别呢?

每一个本地库下都有一个.git的隐藏文件夹,文件夹中的文件保存着跟这个本地库相关的信息

首先来看下其中的config文件

[plain] view plain copy
  1. [core]  
  2.     repositoryformatversion = 0  
  3.     filemode = false  
  4.     bare = false  
  5.     logallrefupdates = true  
  6.     symlinks = false  
  7.     ignorecase = true  
  8.     hideDotFiles = dotGitOnly  
  9. [remote "origin"]  
  10.     url = git@github.com:seanzou88/fetch.git  
  11.     fetch = +refs/heads/*:refs/remotes/origin/*  
  12. [branch "master"]  
  13.     remote = origin  
  14.     merge = refs/heads/master  

从这个文件中我们可以了解到:

1,本地库的当前分支为master,其关联的远程库名称为origin(不同的名称可以指向同一个远程库,参见git remote命令)

2,远程库origin所在的位置为(URL):git@github.com:seanzou88/fetch.git

然后可以查看.git文件夹下的HEAD文件:

[plain] view plain copy
  1. ref: refs/heads/master  

其指向.git\refs\heads\master文件

[plain] view plain copy
  1. ce71505b3626a3648b2c32ea2081d65049cad300  

这个文件中保存的是本地库中最新的commit id

.git\refs文件夹很有意思,面分为3个文件夹

heads文件夹前面说过了

remotes文件夹中的每一个文件夹代表一个远程库名称(git remote),其中的每个文件关联远程库的一个分支,其中保存该分支的最新commit id

.git\logs文件夹下保存的是.git\refs文件夹下相应文件的变更记录

准备工作到此结束,下面可以具体看看git fetch和git pull之间的区别了

 

git fetch origin

本地的latest commit id为:ce71505b3626a3648b2c32ea2081d65049cad300

githup上的latest commit id为:ab8cd391f978fe5384a78c92001ef8ae861046f0

before:

.git\refs\heads\master

[plain] view plain copy
  1. ce71505b3626a3648b2c32ea2081d65049cad300  

.git\refs\remotes\origin\master

[plain] view plain copy
  1. ce71505b3626a3648b2c32ea2081d65049cad300  

.git\logs\refs\heads\master

[plain] view plain copy
  1. 0000000000000000000000000000000000000000   
  2.         ce71505b3626a3648b2c32ea2081d65049cad300   
  3.         ......    
  4.         commit (initial): first commit   

.git\logs\refs\remotes\origin\master

[plain] view plain copy
  1. 0000000000000000000000000000000000000000   
  2.         ce71505b3626a3648b2c32ea2081d65049cad300   
  3.         ......    
  4.         update by push  

after:

.git\refs\heads\master(不变)

.git\refs\remotes\origin\master

[plain] view plain copy
  1. ab8cd391f978fe5384a78c92001ef8ae861046f0  

.git\logs\refs\heads\master(不变)

.git\logs\refs\remotes\origin\master

[plain] view plain copy
  1. 0000000000000000000000000000000000000000   
  2.         ce71505b3626a3648b2c32ea2081d65049cad300   
  3.         ......        
  4.         update by push  
  5. ce71505b3626a3648b2c32ea2081d65049cad300   
  6.         ab8cd391f978fe5384a78c92001ef8ae861046f0   
  7.         ......    
  8.         fetch origin: fast-forward  

本地库并没有变化,也就是说,git fetch只会将本地库所关联的远程库的commit id更新至最新

HEAD没有变化很容易理解,因为本地库并没有变化

 

git pull origin master:master

本地的latest commit id为:3643a1a65fc88ae0e9f28f12168629758d027415

githup上的latest commit id为:64df093f73294d82a3adce9694871b9fac2aecfb

before:

.git\refs\heads\master

[plain] view plain copy
  1. 3643a1a65fc88ae0e9f28f12168629758d027415  

.git\refs\remotes\origin\master

[plain] view plain copy
  1. 3643a1a65fc88ae0e9f28f12168629758d027415  

.git\logs\refs\heads\master

[plain] view plain copy
  1. 0000000000000000000000000000000000000000   
  2.         3643a1a65fc88ae0e9f28f12168629758d027415   
  3.         ......    
  4.         commit (initial): first commit  

.git\logs\refs\remotes\origin\master

[plain] view plain copy
  1. 0000000000000000000000000000000000000000   
  2.         3643a1a65fc88ae0e9f28f12168629758d027415   
  3.         ......    
  4.         update by push  

after:

.git\refs\heads\master

[plain] view plain copy
  1. 64df093f73294d82a3adce9694871b9fac2aecfb  

.git\refs\remotes\origin\master(不变)

.git\logs\refs\heads\master

[plain] view plain copy
  1. 0000000000000000000000000000000000000000   
  2.         3643a1a65fc88ae0e9f28f12168629758d027415   
  3.         ......    
  4.         commit (initial): first commit  
  5. 3643a1a65fc88ae0e9f28f12168629758d027415   
  6.         64df093f73294d82a3adce9694871b9fac2aecfb   
  7.         ......    
  8.         pull origin master:master: fast-forward  

.git\logs\refs\remotes\origin\master(不变)

本地库更新至最新,git pull会将本地库更新至远程库的最新状态

由于本地库进行了更新,HEAD也会相应的指向最新的commit id

所以虽然从结果上来看,git pull = git fetch + git merge,但是从文件中保存的commit id来看,实现上不是这样实现的

为了更好的理解,画了个图:


文章转自:https://blog.csdn.net/a19881029/article/details/42245955

git fetch, git pull, git pull -rebase区别

1、git fetch vs  git pull 都是从远程拉取代码到本地,git fetch只是拉取到本地,git pull不仅拉取到本地还merge到本地分支中。所以git pull是git f...
  • duomengwuyou
  • duomengwuyou
  • 2016-04-20 13:51:32
  • 6880

详解git fetch与git pull的区别

git fetch和git pull都可以将远端仓库更新至本地那么他们之间有什么区别呢?想要弄清楚这个问题有有几个概念不得不提。FETCH_HEAD: 是一个版本链接,记录在本地的一个文件中,指向着目...
  • riddle1981
  • riddle1981
  • 2017-07-11 00:31:15
  • 4009

git fetch pull checkout区别

Git中从远程的分支获取最新的版本到本地有这样2个命令: 1. git fetch:相当于是从远程获取最新版本到本地,不会自动merge     git fetch origin mastergi...
  • crazyhacking
  • crazyhacking
  • 2015-01-15 17:50:42
  • 8417

git fetch和pull的区别

Git中从远程的分支获取最新的版本到本地有这样2个命令: 1. git fetch:相当于是从远程获取最新版本到本地,不会自动mergegit fetch origin master git log...
  • lonewolf521125
  • lonewolf521125
  • 2015-06-05 09:53:55
  • 3205

git 使用(9)git pull和git fetch、git reset 和 git revert 的区别用法

http://blog.csdn.net/hudashi/article/details/7664460http://hittyt.iteye.com/blog/1961386
  • yangyi2083334
  • yangyi2083334
  • 2015-11-20 10:34:30
  • 1219

git fetch, rebase,pull,merge 区别

What are the differences between git pull and git fetch? In the simplest terms, git pull does...
  • carolzhang8406
  • carolzhang8406
  • 2015-11-11 14:41:59
  • 1623

git clone,push,pull,fetch命令详解。(转载)

本文转载自 http://www.ruanyifeng.com/blog/2014/06/git_remote.html Git是目前最流行的版本管理系统,学会Git几乎成了开发者的必备技能...
  • u012575819
  • u012575819
  • 2016-01-21 10:30:40
  • 18411

github: reset 与 rebase, pull 与 fetch 的区别

reset 与 rebase 完全不同的两个命令.reset的意思是回退你的代码到某一个具体的版本,rebase是指回退你个commit到某一次commit. git-reset 会修改 ....
  • changtianshuiyue
  • changtianshuiyue
  • 2016-06-09 15:15:46
  • 1740

Egit fetch from upstream 与 pull的区别

原文: http://www.tech126.com/git-fetch-pull/  Git中从远程的分支获取最新的版本到本地有这样2个命令: 1. git fetch:相当于是从远程获...
  • lwqxmu
  • lwqxmu
  • 2016-11-23 10:59:09
  • 5372

git fetch, merge, pull, push需要注意的地方

在git操作中,我们经常会用到fetch, merge, pull和push等命令,以下是一些我们需要注意的地方。 给大家准备了参考资料: 1. Whatʼs a Fast Forward Mer...
  • hutaoer06051
  • hutaoer06051
  • 2013-03-14 17:00:05
  • 10457
收藏助手
不良信息举报
您举报文章:git fetch和git pull之间的区别
举报原因:
原因补充:

(最多只允许输入30个字)