• (转)git fetch + merge 和 git pull 的区别


    转自:http://blog.csdn.net/a19881029/article/details/42245955

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

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

    首先来看下其中的config文件

    [plain] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    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
     
     在CODE上查看代码片派生到我的代码片
    1. ref: refs/heads/master  

    其指向.git efsheadsmaster文件

    [plain] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. ce71505b3626a3648b2c32ea2081d65049cad300  

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

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

    heads文件夹前面说过了

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

    .gitlogs文件夹下保存的是.git efs文件夹下相应文件的变更记录

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

    git fetch origin

    本地的latest commit id为:ce71505b3626a3648b2c32ea2081d65049cad300

    githup上的latest commit id为:ab8cd391f978fe5384a78c92001ef8ae861046f0

    before:

    .git efsheadsmaster

    [plain] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. ce71505b3626a3648b2c32ea2081d65049cad300  

    .git efs emotesoriginmaster

    [plain] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. ce71505b3626a3648b2c32ea2081d65049cad300  

    .gitlogs efsheadsmaster

    [plain] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. 0000000000000000000000000000000000000000   
    2.         ce71505b3626a3648b2c32ea2081d65049cad300   
    3.         ......    
    4.         commit (initial): first commit   

    .gitlogs efs emotesoriginmaster

    [plain] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. 0000000000000000000000000000000000000000   
    2.         ce71505b3626a3648b2c32ea2081d65049cad300   
    3.         ......    
    4.         update by push  

    after:

    .git efsheadsmaster(不变)

    .git efs emotesoriginmaster

    [plain] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. ab8cd391f978fe5384a78c92001ef8ae861046f0  

    .gitlogs efsheadsmaster(不变)

    .gitlogs efs emotesoriginmaster

    [plain] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    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 efsheadsmaster

    [plain] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. 3643a1a65fc88ae0e9f28f12168629758d027415  

    .git efs emotesoriginmaster

    [plain] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. 3643a1a65fc88ae0e9f28f12168629758d027415  

    .gitlogs efsheadsmaster

    [plain] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. 0000000000000000000000000000000000000000   
    2.         3643a1a65fc88ae0e9f28f12168629758d027415   
    3.         ......    
    4.         commit (initial): first commit  

    .gitlogs efs emotesoriginmaster

    [plain] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. 0000000000000000000000000000000000000000   
    2.         3643a1a65fc88ae0e9f28f12168629758d027415   
    3.         ......    
    4.         update by push  

    after:

    .git efsheadsmaster

    [plain] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. 64df093f73294d82a3adce9694871b9fac2aecfb  

    .git efs emotesoriginmaster(不变)

    .gitlogs efsheadsmaster

    [plain] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. 0000000000000000000000000000000000000000   
    2.         3643a1a65fc88ae0e9f28f12168629758d027415   
    3.         ......    
    4.         commit (initial): first commit  
    5. 3643a1a65fc88ae0e9f28f12168629758d027415   
    6.         64df093f73294d82a3adce9694871b9fac2aecfb   
    7.         ......    
    8.         pull origin master:master: fast-forward  

    .gitlogs efs emotesoriginmaster(不变)

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

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

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

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

  • 相关阅读:
    Linux权限及归属管理
    Linux账户管理
    随笔记录 磁盘坏道故障 2019.8.7
    随笔记录 MBR扇区故障系统备份与还原 2019.8.7
    随笔记录 grub引导故障修复 2019.8.7
    随笔记录 综合训练 2019.8.5
    随笔记录 磁盘配额2019.8.2
    随笔记录 2019.7.31
    随笔记录 2019.7.31
    随笔记录 linux命令 2019.7.29
  • 原文地址:https://www.cnblogs.com/sunshisonghit/p/6806255.html
Copyright © 2020-2023  润新知