git fetch和git pull的区别解析
简朴概括两者的概念
git fetch是将遥程主机的最新内容拉到本地,用户在检查了以后决定是否合并到工作本机分支中。
而git pull 则是将遥程主机的最新内容拉下来后直接合并,即:git pull = git fetch + git merge,这样可能会产生冲突,需要手动解决。
1.两者相同点
先在作用上他们的功能是大致相同的,都是起到了更新代码的作用。
2.不同点
首先我们要说简朴说git的运行机制。git分为本地仓库和遥程仓库,我们一般情况都是写完代码,commit到本地仓库(生成本地仓的commit ID,代表当前提交代码的版本号),然后push到遥程仓库(记录这个版本号),这个流程大家都认识。
我们本地的git文件夹里面对应也存储了git本地仓库master分支的commit ID 和 跟踪的遥程分支orign/master的commit ID(可以有多个遥程仓库)。那什么是跟踪的遥程分支呢,打开git文件夹可以观到如下文件:
.git/refs/head/[本地分支]
.git/refs/remotes/[正在跟踪的分支]
其中head就是本地分支,remotes是跟踪的遥程分支,这个类型的分支在某种类型上是十分相似的,他们都是表示提交的SHA1校验和(就是commitID)。但是,不管他们是如何的相似,他们还是有一个重大的区别:更改遥端跟踪分支只能用git fetch,或者是git push后作为副产品(side-effect)来改变。我们无法直接对遥程跟踪分支操作,我们必须先切归本地分支然后创建一个新的commit提交。
拉取不同
1、Git fetch:Git fetch会将数据拉取到本地仓库 - 它并不会自动合并或修改当前的工作。
2、git pull:git pull是从遥程获取最新版本并merge到本地,会自动合并或修改当前的工作。
commitID不同
1、Git fetch:使用Git fetch更新代码,本地的库中master的commitID不变,还是等于1。
2、git pull:使用git pull更新代码,本地的库中master的commitID发生改变,变成了2。
分支(branch)的基本操作
git branch //查观本地所有分支 git branch -r //查观遥程所有分支 git branch -a //查观本地和遥程的所有分支 git branch <branchname> //新建分支 git branch -d <branchname> //删除本地分支 git branch -d -r <branchname> //删除遥程分支,删除后还需推送到服务器 git push origin:<branchname> //删除后推送至服务器 git branch -m <oldbranch> <newbranch> //重命名本地分支 /** *重命名遥程分支: *1、删除遥程待修改分支 *2、push本地新分支到遥程服务器 */ //git中一些选项解释: -d --delete:删除 -D --delete --force的快捷键 -f --force:强制 -m --move:移动或重命名 -M --move --force的快捷键 -r --remote:遥程 -a --all:所有
3.git fetch用法
git fetch 命令:
$ git fetch <遥程主机名> //这个命令将某个遥程主机的更新全部取归本地
假如只想取归特定分支的更新,可以指定分支名:
$ git fetch <遥程主机名> <分支名> //注重之间有空格
最常见的命令如取归origin 主机的master 分支:
$ git fetch origin master
取归更新后,会返归一个FETCH_HEAD ,指的是某个branch在服务器上的最新状态,我们可以在本地通过它查观刚取归的更新信息:
$ git log -p FETCH_HEAD
可以观到返归的信息包括更新的文件名,更新的作者和时间,以及更新的代码(19行红色[删除]和绿色[新增]部分)。
我们可以通过这些信息来判定是否产生冲突,以确定是否将更新merge到当前分支。
4.git pull 用法
前面提到,git pull 的过程可以理解为
git fetch origin master //从遥程主机的master分支拉取最新内容 git merge FETCH_HEAD //将拉取下来的最新内容合并到当前所在的分支中
即将遥程主机的某个分支的更新取归,并与本地指定的分支合并,完整格式可表示为:
$ git pull <遥程主机名> <遥程分支名>:<本地分支名>
假如遥程分支是与当前分支合并,则冒号后面的部分可以省略:
$ git pull origin next
5.拉取遥程分支
git fetch //代码拉取到本地之后 git branch //查观分支 git checkout 遥程分支的分支名
参考文章
https://blog.csdn.net/qq_36113598/article/details/78906882
https://blog.csdn.net/weixin_41975655/article/details/82887273
到此这篇关于git fetch和git pull的区别的文章就介绍到这了,更多相关git fetch和git pull的区别内容请搜索以前的文章或继承浏览下面的相关文章希望大家以后多多支持!