git fetch
2016-07-10 12:54
225 查看
http://www.ruanyifeng.com/blog/2012/07/git.html 流程
默认情况下,git fetch取回所有分支(branch)的更新。如果只想取回特定分支的更新,可以指定分支名。
$ git fetch <远程主机名> <分支名>
比如,取回origin主机的master分支。
$ git fetch origin master
git fetch <远程主机名> <分支名>
git checkout -b newBrach origin/master
git diff
一般来说, 存在两种情况:
如果没有显式的指定
远程分支, 则远程分支的
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 rebase origin/master
Git如何进行分支管理?
1、创建分支
创建分支很简单:git branch <分支名>
2、切换分支
git checkout <分支名>
该语句和上一个语句可以和起来用一个语句表示:git checkout -b <分支名>
3、分支合并
比如,如果要将开发中的分支(develop),合并到稳定分支(master),
首先切换的master分支:git checkout master。
然后执行合并操作:git merge develop。
如果有冲突,会提示你,调用git status查看冲突文件。
解决冲突,然后调用git add或git rm将解决后的文件暂存。
所有冲突解决后,git commit 提交更改。
4、分支衍合
分支衍合和分支合并的差别在于,分支衍合不会保留合并的日志,不留痕迹,而 分支合并则会保留合并的日志。
要将开发中的分支(develop),衍合到稳定分支(master)。
首先切换的master分支:git checkout master。
然后执行衍和操作:git rebase develop。
如果有冲突,会提示你,调用git status查看冲突文件。
解决冲突,然后调用git add或git rm将解决后的文件暂存。
所有冲突解决后,git rebase --continue 提交更改。
5、删除分支
执行git branch -d <分支名>
如果该分支没有合并到主分支会报错,可以用以下命令强制删除git branch -D <分支名>
http://winuxxan.blog.51cto.com/2779763/508955
相关文章推荐
- 用Javascript控制Table的行移动
- js 定位到某个锚点
- HTML的按钮,文本框等零件
- jsp标签
- caffe 其他层及参数介绍
- CSS3渐变笔记(上)
- The Smallest Difference
- caffe 学习系列激活层及其参数
- 校验字符串是否是JSON格式,将不规则展示的json格式的字符串进行规则展示(json格式化)
- caffe 学习系列 视觉层
- NodeJs--url
- NodeJs--url
- caffe 学习系列 数据层介绍
- 【ReactNative】react-native 布局
- angular中$watch踩的坑
- 来看看机智的前端童鞋怎么防盗
- Javascript DOM Document|Element|Attribute对象方法详解
- HTML4 和 HTML5 的10个区别
- HTML5的开发工具
- 剑指offer43--字符串转化成整数