12.Git分支-推送(push)、跟踪分支、拉取(pull)、删除远程分支
1.推送
本地的分支并不会自动与远程仓库同步,你可以显示的向远程仓库推送你的分支。例如你在本地创建了一个dev分支,你想其他的人和你一样在dev之下进行工作,可以使用 git push <remote> <branch> 将自己的分支推送到远程仓库。
git push origin dev 即可。
下一次其他的人从服务器上抓取数据的时候,他们会在本地生成一个远程分支origin/serverfix,指向服务器的serverfix分支的引用。
如果你在推送分支的时候,想给分支另取一个名字,可以使用 git push <remote> <branch>:<remote-branch>
例如 git push <origin> <dev>:<dev-gq> ,将本地的dev分支推送到远程,并且远程分支命名为dev-gq。
注意: 当使用git fetch从远程仓库抓取到新的远程跟踪分支时,本地不会自动生成一份可编辑的副本。换句话说,也就是本地不会自动生成一个新的dev分支,只有一个不可以进行修改的origin/dev分支。
你可以运行 git merge <origin/dev> 将这些跟踪合并到你正在工作的分支上。当然你也可以在远程跟踪分支上新建一个dev分支,git checkout -b dev origin/dev 这句命令会给你再本地新建一个dev分支,并且起点位于origin/dev。
上面两段话的意思就是,使用git fetch拉取的更新,不会自动被合并到分支中去,workingtree中不会显示这个分支的修改,可以自己执行git merge <origin/dev>命令将origin/dev的更改合并到当前所在的分支,当然也可以新建一个分支dev,然后merge到新建的本地dev分支中;还有一种办法是使用git checkout -b dev origin/dev,这个和使用git merge origin/dev dev是相同的效果。
2.跟踪分支
从远程跟踪分支检出一个本地分支,会自动创建一个跟踪分支(有时候也叫做上游分支)。如果在一个跟踪分支上运行git pull,Git能够知道从哪里去拉取数据。
当克隆一个仓库的时候,一般会自动创建一个跟踪origin/master的跟踪分支master。
git checkout -b <branch> <remote>/<branch> //创建一个跟踪分支
例子:git checkout -b dev origin/dev
相比于上述命令,Git提供了一个快捷方式来创建跟踪分支: git checkout --track <remote>/<branch>
例子:git checkout --track origin/dev 在本地创建一个dev跟踪分支,它起始于origin/dev分支。
如果不想要使用dev这个分支作为本地分支的名字,可以使用 git checkout --track dev-gq origin/dev 将本地分支的名字命名为dev-gq。
设置一个已有的跟踪分支跟踪刚刚拉取下来的远程分支,或者要修改正在跟踪的上游分支,可以使用git branch带上-u或者--set-upstream-to参数来进行设置。
例子: git branch -u origin/dev 设置本地跟踪分支dev,跟踪远程跟踪分支origin/dev。
git branch -vv 会将所有的本地分支列出来,可以看到各个分支正在跟踪哪个远程分支,本地分支相对于远程分支来说,领先或者落后了多少。
$ git branch -vv
iss53 7e424c3 [origin/iss53: ahead ] forgot the brackets
master 1ae2a45 [origin/master] deploying index fix
* serverfix f8674d9 [teamone/server-fix-good: ahead , behind ] this
should do it
testing 5ea463a trying something new
注意:这条命令进行对比的远程分支是来自于你最后一次从服务器上抓取的数据,并不是最新的数据,这时候,你可以运行
git fetch --all
git branch -vv
来得到最新的数据。
3.拉取
当使用 git fetch 从远程仓库抓取数据的时候,它并不会修改工作目录中的内容,它只会获取数据,然后需要你自己进行合并。然而,还有一个 git pull 命令,它会查找当前分支所跟踪的服务器与分支,从服务器上抓取数据,然后尝试合并进入当前分支。
git pull = git fetch + git merge
4.删除远程分支
假设你已经通过远程分支完成了所有的工作,也就是所远程分支上的代码已经合并到了master中,并且这个远程分支决定以后不再使用,可以使用带有--delete的git push命令来删除远程分支。
git push origin --delete dev //删除远程分支dev
12.Git分支-推送(push)、跟踪分支、拉取(pull)、删除远程分支的更多相关文章
- [git]本地查看,重命名,拉取,删除远程分支
1.git branch -a 查看所有的分支,包含远程仓库.-av:同时显示最近的一个commit信息. 2.git checkout -b newBranch origin/master 拷贝一份 ...
- git 拉取指定的远程分支(三种方式)
直接拉取 git clone -b ants git@github.com:Ants-double/CareerJava.git git clone -b 远程分支名 仓库地址 本地已经有相关的仓库代 ...
- Git push将本地版本库的分支推送到远程服务器上对应的分支
在使用git commit命令将修改从暂存区提交到本地版本库后,只剩下最后一步将本地版本库的分支推送到远程服务器上对应的分支了,如果不清楚版本库的构成,可以查看我的另一篇,git 仓库的基本结构. g ...
- 版本控制git之三-多人协作 变基 推送 拉取 删除远程分支
版本控制git之三-多人协作 wangfeng7399已关注0人评论350人阅读2019-02-20 21:33:08 如果你想获得一份已经存在了的 Git 仓库的拷贝,比如说,你想为某个开源 ...
- git本地分支推送到远程分支
1.创建的创建和初始化 创建git仓库可以在远端创建一个仓库, 然后check到本地,在本地的文件里创建工程文件,然后提交 也可以将本地现有的工程和远端的空仓库关联 本地创建了一个工程 iOSDemo ...
- git创建新分支推送到远程
1.创建本地分支 git branch 分支名,例如:git branch 2.0.1.20120806 注:2.0.1.20120806是分支名称,可以随便定义. 2.切换本地分支 git ch ...
- Git撤回已经推送(push)至远程仓库提交(commit)的版本
背景 所以,经常会遇到已经提交远程仓库,但是又不是我想要的版本,要撤下来. 回退版本一般使用git reset,又分为: # 不删除工作空间改动代码,撤销commit,不撤销git add . git ...
- Git查看、删除远程分支和tag
本站文章除注明转载外,均为本站原创或者翻译. 本站文章欢迎各种形式的转载,但请18岁以上的转载者注明文章出处,尊重我的劳动,也尊重你的智商: 本站部分原创和翻译文章提供markdown格式源码,欢迎使 ...
- git使用,多分支合并代码解决冲突,git删除远程分支,删除远程master默认分支方法
git使用,多分支合并代码解决冲突,git删除远程分支,删除远程master默认分支方法提交代码流程:1.先提交代码到自己分支上2.切换到devlop拉取代码合并到当前分支3.合并后有变动的推送到自己 ...
随机推荐
- C. mathematican 的二进制
题解: subtask1:爆搜,没状压dp的分 subtask2,3:统计有几个操作就好了,分治ntt优化 subtask4,5: 发现和操作顺序无关,然后我们考虑用分治ntt优化 每个的贡献是$n+ ...
- Linux从入门到进阶全集——【第十四集:Shell基础命令】
1,Shell就是命令行执行器 2,作用:将外层引用程序的例如ls ll等命令进行解释成01表示的二进制代码给内核,从而让硬件执行:硬件的执行结果返回给shell,shell解释成我们能看得懂的代码返 ...
- RabbitMQ中交换机的消息分发机制
RabbitMQ是一个消息代理,它接受和转发消息,是一个由 Erlang 语言开发的遵循AMQP协议的开源实现.在RabbitMQ中生产者不会将消息直接发送到队列当中,而是将消息直接发送到交换机(ex ...
- idea看源码
idea看源码,可以直接搜索.看接口具体调用的是哪个类里面的方法(多态)
- 关于二进制枚举-计蒜客-得到整数X
某君有 n个互不相同的正整数,现在他要从这 n 个正整数之中无重复地选取任意个数,并仅通过加法凑出整数 X.求某君有多少种不同的方案来凑出整数 X. 输入格式 第一行,输入两个整数 n,X(1≤n≤2 ...
- Linux-day2-上课笔记
UGO权限 1) 文件对于拥有者的权限 User 2) 文件对于所属组里面的用户的权限 Group 3) 文件对于其他人的权限 Others 对于文件的权限 1)对于文件可读 r 2)对于文件 ...
- 多标签caffe重新编译
说明: Caffe自带的图像转LMDB接口只支持单label,对于多label的任务,可以使用HDF5的格式,也可以通过修改caffe代码来实现.本篇文章介绍怎么通过修改DataLayer来实现带Mu ...
- ISP PIPLINE (九_2) Denoise 之 time domain denoise
时域噪声是空域噪声在时间上波动的一种描述. 1.多帧平均去噪法 1.1 理论: 1.2 帧数增加,噪声减小: 1.3 IIR滤波器的效果 2.1中的两种方法在拍摄视频的时候,如果有运动物体,则会出现拖 ...
- SQL功能分类
DDL 数据定义语言:创建表 ,库,列 DML 数据操作语言:用来操作数据库中的记录 DQL 数据查询语言 :用来查询数据 DCL 数据控制语言:定义访问权限和安全级别 —————————————— ...
- SpringInAction学习笔记(一):核心概念
Spring自带了多种应用上下文 AnnotationConfigApplicationContext:从一个或多个java配置类中加载应用上下文 AnnotationConfigWebApplica ...