git命令之git fetch的用法
来源:互联网 发布:suse linux和linux区别 编辑:程序博客网 时间:2024/05/29 15:12
而理解fetch
的关键, 是理解FETCH_HEAD
.这里需要解释下什么是FETCH_HEAD??
FETCH_HEAD指的是:
某个branch在服务器上的最新状态'.
执行过fetch操作的项目'都会存在一个FETCH_HEAD列表,
每一个
这个列表保存在.git/FETCH_HEAD
文件中, 其中每一行对应于远程服务器的一个分支
.
当前分支指向的FETCH_HEAD, 就是这个文件第一行对应的那个分支
.一般来说, 存在两种情况:
如果没有显式的指定
远程分支
, 则远程分支的master
将作为默认的FETCH_HEAD.如果指定了
远程分支
, 就将这个远程分支作为FETCH_HEAD.常见的git fetch 使用方式包含以下四种:
git fetch
这一步其实是执行了两个关键操作:
-创建并更新
所有远程分支的本地远程分支
.
- 设定当前分支的FETCH_HEAD
为远程服务器的master分支
(上面说的第一种情况)需要注意的是: 和push不同, fetch会自动获取远程`新加入'的分支.
git fetch origin
同上, 只不过手动指定了remote.
git fetch origin branch1
设定当前分支的
FETCH_HEAD' 为
远程服务器的branch1分支`.注意: 在这种情况下, 不会在本地创建
本地远程分支
, 这是因为:这个操作是
git pull origin branch1
的第一步, 而对应的pull操作,并不会在本地创建新的branch.一个附加效果是:
这个命令可以用来测试远程主机的远程分支branch1是否存在, 如果存在, 返回0, 如果不存在, 返回128, 抛出一个异常.
git fetch origin branch1:branch2
只要明白了上面的含义, 这个就很简单了,
- 首先执行上面的fetch操作
使用远程branch1分支在本地创建branch2(但不会切换到该分支),
如果本地不存在branch2分支, 则会自动创建一个新的branch2分支,
如果本地存在branch2分支, 并且是`fast forward', 则自动合并两个分支, 否则, 会阻止以上操作.
git fetch origin :branch2
等价于: git fetch origin master:branch2
- git命令之git fetch的用法
- git命令之git fetch的用法
- git命令之git fetch的用法
- git命令之git fetch的用法
- git命令之git fetch的用法
- git命令之git fetch的用法
- git命令之git fetch 用法 2
- git命令之git fetch 用法 2
- 学习理解GIT命令之git fetch的用法
- git命令之fetch
- git的fetch用法
- git命令之git rebase 的用法
- git命令之git remote的用法
- git命令之git remote的用法
- git命令之git rebase 的用法
- git命令之git remote的用法
- git命令之git remote的用法
- git 命令之git cloned 的用法
- 开源的反向代理项目推荐
- Linux下的top命令
- 移植内核学习笔记2-----修改分区及制作根文件系统
- 【李叫兽】为什么你有10年经验,但成不了专家?
- 进程间通信(Interprocess Communications)
- git命令之git fetch的用法
- 利用channel在goroutins之间控制同步和传递数据
- 【OpenCV学习笔记 008】基于形态学运算的图像变换
- LeetCode练习-难题卷
- 我的ubuntu问题汇总
- 从nsq中学习如何优雅的退出go 网络程序
- [阶段二]Android UI窗口组件
- Deepin logo国内 Linux 发行版 Deepin
- Go原子计数