git fetch & pull详解

一、简单归纳
先用一张图来理一下git fetch和git pull的概念:git

 

能够简单的归纳为:
git fetch是将远程主机的最新内容拉到本地,用户在检查了之后决定是否合并到工做本机分支中。
而git pull 则是将远程主机的最新内容拉下来后直接合并,即:git pull = git fetch + git merge,这样可能会产生冲突,须要手动解决。
下面咱们来详细了解一下git fetch 和git pull 的用法。 服务器

二、分支的概念
在介绍两种方法以前,咱们须要先了解一下分支的概念: 
分支是用来标记特定代码的提交,每个分支经过SHA1sum值来标识,因此对分支的操做是轻量级的,你改变的仅仅是SHA1sum值。
以下图所示,当前有2个分支,A,C,E属于master分支,而A,B,D,F属于dev分支。
A----C----E(master)
\

B---D---F(dev)
1
2
3
它们的head指针分别指向E和F,对上述作以下操做:
git checkout master //选择or切换到master分支
g
git merge dev //将dev分支合并到当前分支(master)中
1
2
合并完成后:
A---C---E---G(master)
\ /

B---D---F(dev)
1
2
3
如今ABCDEFG属于master,G是一次合并后的结果,是将E和F的代码合并后的结果,可能会出现冲突。而ABDF依然属于dev分支。能够继续在dev的分支上进行开发:
A---C---E---G---H(master)
\ /

B---D---F---I(dev)fetch

1
2
3
4
分支(branch)的基本操做:
git branch //查看本地全部分支 指针

 

g
git branch -r //查看远程全部分支blog

 

g
git branch -a //查看本地和远程的全部分支开发

 

g
git branch <branchname> //新建分支rem

 

g
git branch -d <branchname> //删除本地分支it

 

g
git branch -d -r <branchname> //删除远程分支,删除后还需推送到服务器
g
git push origin:<branchname> //删除后推送至服务器ast

 

g
git branch -m <oldbranch> <newbranch> //重命名本地分支方法

/**
*
*重命名远程分支:
*
*一、删除远程待修改分支
*
*二、push本地新分支到远程服务器
*
*/


/
//git中一些选项解释:

 

-d
--delete:删除

-D
--delete --force的快捷键

-f
--force:强制

-m
--move:移动或重命名

-M
--move --force的快捷键

-r
--remote:远程

-a
--all:全部
 
三、git fetch 用法
git fetch 命令:
$ git fetch <远程主机名> //这个命令将某个远程主机的更新所有取回本地
1
若是只想取回特定分支的更新,能够指定分支名:
$ git fetch <远程主机名> <分支名> //注意之间有空格
1
最多见的命令如取回origin 主机的master 分支:
$ git fetch origin master
1
取回更新后,会返回一个FETCH_HEAD ,指的是某个branch在服务器上的最新状态,咱们能够在本地经过它查看刚取回的更新信息:
$ git log -p FETCH_HEAD
1
如图: 

 

能够看到返回的信息包括更新的文件名,更新的做者和时间,以及更新的代码(19行红色[删除]和绿色[新增]部分)。
咱们能够经过这些信息来判断是否产生冲突,以肯定是否将更新merge到当前分支。 

四、git pull 用法前面提到,git pull 的过程能够理解为:git fetch origin master //从远程主机的master分支拉取最新内容 ggit merge FETCH_HEAD //将拉取下来的最新内容合并到当前所在的分支中12即将远程主机的某个分支的更新取回,并与本地指定的分支合并,完整格式可表示为:$ git pull <远程主机名> <远程分支名>:<本地分支名>1若是远程分支是与当前分支合并,则冒号后面的部分能够省略:$ git pull origin next

相关文章
相关标签/搜索