文档章节

Git - Your branch and 'origin/xxx' have diverged

bengozhong
 bengozhong
发布于 2017/09/01 11:08
字数 465
阅读 29
收藏 0

当前工作的Git仓库模型为:

upstream
   |
origin
   |
local copy
  • 1
  • 2
  • 3
  • 4
  • 5
  • 1
  • 2
  • 3
  • 4
  • 5

Git fetch 、merge以后出现分叉

git fetch upstream上游代码后执行git merge,然后git status发现Git分支出现分叉 (不是在rebase之后出现的情况下)。

提示类似下面的错误:

Your branch and 'origin/xxx' have diverged,
and have 1 and 1 different commit(s) each, respectively.
  • 1
  • 2
  • 1
  • 2

出现分叉的原因是存在两种独立的提交(每种可能有多个提交): 一种是来自你本地分支副本的提交,另外的提交来自远程分支副本。(通常是由于另外一个人在上游相同的分支做了提交)

一个示例的git提交历史树:


    ... o ---- o ---- A ---- B  origin/branch_xxx (upstream work)
                       \
                        C  branch_xxx (your work)
  • 1
  • 2
  • 3
  • 4
  • 5
  • 1
  • 2
  • 3
  • 4
  • 5

这个时候解决分叉的办法就是:

在本地分支上,执行:

git rebase
  • 1
  • 1

rebase以后的git提交历史树为:

    ... o ---- o ---- A ---- B  origin/branch_xxx (upstream work)
                              \
                               C`  branch_xxx (your work)
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3

rebase以后提示同样的错误

rebase以后可能出现相同的错误,这是因为你在执行rebase之前,已经往你的origin上面push了提交。由于rebase会重写历史提交记录,因此你的本地和你的origin的历史提交状态是不同的,同样产生了分叉:

rebase之前的git提交历史树:


    ... o ---- o ---- A ---- B  master, origin/master
                       \
                        C  branch_xxx, origin/branch_xxx
  • 1
  • 2
  • 3
  • 4
  • 1
  • 2
  • 3
  • 4

执行rebase之后的git提交历史树:

    ... o ---- o ---- A ---------------------- B  master, origin/master
                       \                        \
                        C  origin/branch_xxx     C` branch_xxx
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3

这时候,你必须确定你是处于上面描述的情况,解决方案就是强制push到你的origin上游,执行下面命令可以解决:

git push origin branch_xxx -f

© 著作权归作者所有

bengozhong
粉丝 21
博文 522
码字总数 539819
作品 0
深圳
技术主管
私信 提问
Git分支Branch使用指南

引言: Git由于其良好的分布式特性,被广为采用,本文将综述其核心的关键指令。 创建Branch git checkout -b ‘branch name’ 查看远程分支 git branch -a Options: -a 查看所有的branch -r...

architect刘源源
2018/02/23
44
0
fork, clone, add, commit, fetch, rebase, push流程测试

假定原作者的名称叫gittest, 我叫uniquejava. 原作者新建了一个项目叫nocrazy。 于是路径为gittest/nocrazy 做了两次提交 提交一: a.txt this is a 提交二:b.txt this is b. 我cyper某天f...

cyper
2015/08/26
245
0
Git专题------Git 常用命令速查表(图文+表格)

cover:http://www.jb51.net/article/55442.htm 一、 Git 常用命令速查 git branch 查看本地所有分支 git status 查看当前状态 git commit 提交 git branch -a 查看所有的分支 git branch -r ...

鸿蒙无上至尊
2018/05/15
0
0
Git使用入门 - 在Git上新建项目

Git的使用很简单,第一次在客户端获取代码时,直接通过各种IDE的clone方法,可以把Git上的工程get下来即可。后续使用时,新文件用 add、commit、push;获取新版本用 pull 或 fecth,遇到冲突...

酸奶冻芝士
2015/12/23
157
0
git宝典—应付日常工作使用足够的指北手册

最近公司gitlab又迁移,一堆git的命令骚操作,然鹅git命令,感觉还是得复习下——其实,git现在界面操作工具蛮多,比如intellij 自带的git操作插件就不错,gitlab github 插件市场也有很多,...

zhoulujun
04/12
21
0

没有更多内容

加载失败,请刷新页面

加载更多

Spring使用ThreadPoolTaskExecutor自定义线程池及实现异步调用

多线程一直是工作或面试过程中的高频知识点,今天给大家分享一下使用 ThreadPoolTaskExecutor 来自定义线程池和实现异步调用多线程。 一、ThreadPoolTaskExecutor 本文采用 Executors 的工厂...

CREATE_17
今天
5
0
CSS盒子模型

CSS盒子模型 组成: content --> padding --> border --> margin 像现实生活中的快递: 物品 --> 填充物 --> 包装盒 --> 盒子与盒子之间的间距 content :width、height组成的 内容区域 padd......

studywin
今天
7
0
修复Win10下开始菜单、设置等系统软件无法打开的问题

因为各种各样的原因导致系统文件丢失、损坏、被修改,而造成win10的开始菜单、设置等系统软件无法打开的情况,可以尝试如下方法解决 此方法只在部分情况下有效,但值得一试 用Windows键+R打开...

locbytes
昨天
8
0
jquery 添加和删除节点

本文转载于:专业的前端网站➺jquery 添加和删除节点 // 增加一个三和一节点function addPanel() { // var newPanel = $('.my-panel').clone(true) var newPanel = $(".triple-panel-con......

前端老手
昨天
8
0
一、Django基础

一、web框架分类和wsgiref模块使用介绍 web框架的本质 socket服务端 与 浏览器的通信 socket服务端功能划分: 负责与浏览器收发消息(socket通信) --> wsgiref/uWsgi/gunicorn... 根据用户访问...

ZeroBit
昨天
10
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部