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)、删除远程分支的更多相关文章

  1. [git]本地查看,重命名,拉取,删除远程分支

    1.git branch -a 查看所有的分支,包含远程仓库.-av:同时显示最近的一个commit信息. 2.git checkout -b newBranch origin/master 拷贝一份 ...

  2. git 拉取指定的远程分支(三种方式)

    直接拉取 git clone -b ants git@github.com:Ants-double/CareerJava.git git clone -b 远程分支名 仓库地址 本地已经有相关的仓库代 ...

  3. Git push将本地版本库的分支推送到远程服务器上对应的分支

    在使用git commit命令将修改从暂存区提交到本地版本库后,只剩下最后一步将本地版本库的分支推送到远程服务器上对应的分支了,如果不清楚版本库的构成,可以查看我的另一篇,git 仓库的基本结构. g ...

  4. 版本控制git之三-多人协作 变基 推送 拉取 删除远程分支

      版本控制git之三-多人协作 wangfeng7399已关注0人评论350人阅读2019-02-20 21:33:08   如果你想获得一份已经存在了的 Git 仓库的拷贝,比如说,你想为某个开源 ...

  5. git本地分支推送到远程分支

    1.创建的创建和初始化 创建git仓库可以在远端创建一个仓库, 然后check到本地,在本地的文件里创建工程文件,然后提交 也可以将本地现有的工程和远端的空仓库关联 本地创建了一个工程 iOSDemo ...

  6. git创建新分支推送到远程

    1.创建本地分支 git branch 分支名,例如:git branch 2.0.1.20120806 注:2.0.1.20120806是分支名称,可以随便定义.   2.切换本地分支 git ch ...

  7. Git撤回已经推送(push)至远程仓库提交(commit)的版本

    背景 所以,经常会遇到已经提交远程仓库,但是又不是我想要的版本,要撤下来. 回退版本一般使用git reset,又分为: # 不删除工作空间改动代码,撤销commit,不撤销git add . git ...

  8. Git查看、删除远程分支和tag

    本站文章除注明转载外,均为本站原创或者翻译. 本站文章欢迎各种形式的转载,但请18岁以上的转载者注明文章出处,尊重我的劳动,也尊重你的智商: 本站部分原创和翻译文章提供markdown格式源码,欢迎使 ...

  9. git使用,多分支合并代码解决冲突,git删除远程分支,删除远程master默认分支方法

    git使用,多分支合并代码解决冲突,git删除远程分支,删除远程master默认分支方法提交代码流程:1.先提交代码到自己分支上2.切换到devlop拉取代码合并到当前分支3.合并后有变动的推送到自己 ...

随机推荐

  1. PHP将图片转base64编码以及base64图片转换为图片并保存代码

    图片转base64编码 /*图片转换为 base64格式编码*/ $img = 'uploads/01.png'; $base64_img = base64EncodeImage($img); ech ...

  2. How does rt.jar works?

    转载自:https://stackoverflow.com/questions/30222702/how-does-java-link-lib-rt-jar-to-your-app-at-runtim ...

  3. .net 获取配置文件AppSettings的键值

    //AppSettings.config 节点代码 <appSettings> <add key="IsUpdate" value="false&quo ...

  4. Oracle体系结构之内存结构(3)

    Oracle内存结构由系统全局区SGA和程序全局区PGA组成. SGA是实例启动的时候分配的Oracle实例中的一个基本成分. PGA是服务器进程启动时分配. 1.系统全局区SGA 系统全局区SGA由 ...

  5. 在Windows上使用Let加密IIS

    在Windows上使用Let加密IIS https://weblog.west-wind.com/posts/2016/Feb/22/Using-Lets-Encrypt-with-IIS-on-Wi ...

  6. linux去除\r(window中编辑的文本)

    vim -b file 二进制贷款文件:%s/^M//g         # 注意这里使用Ctrl+V+M输入^M 上面的方法我就不行,但是下面的可以: 如果不行可以使用 :%s/\r//

  7. springmvc是如何工作的

    上图便是springmvc的工作流程,看着条条框框的,其实说的直白一点,springmvc就是负责处理用户的需求(request/url),它的负责人(核心组件)就是前端控制器(DispatcherS ...

  8. JVM虚拟机个人理解

    针对于java1.8版本,JVM的系统架构 类加载机制: 堆内存结构图: 面试题:一个对象从创建到销毁经历了什么? 1.new一个对象时,在堆内存中开辟一块空间. 2.给开辟的空间分配一个地址. 3. ...

  9. JS浏览器兼容问题

    一.JS与DOM的兼容性: (一) DOM节点的访问: 1.以前对DOM节点访问一般用“document.All.元素ID属性值”或者“document.元素ID属性值”这种简化的方法,在FireFo ...

  10. LeetCode 81 Search in Rotated Sorted Array II [binary search] <c++>

    LeetCode 81 Search in Rotated Sorted Array II [binary search] <c++> 给出排序好的一维有重复元素的数组,随机取一个位置断开 ...