HEAD DETACHED push origin失败问题
先说HEAD
HEAD是一个头指针,通常情况下指向不同的分支,每个分支对应一个commit(准确的说,每个分支对应多个commit,但是只有一个顶层的commit,而commit之间是简单的线性关系。)
git checkout 其实是修改HEAD文件的内容,让它指向不同的分支。
下面是一个一般的情况:
HEAD (refers to branch 'master')
|
v
a---b---c branch 'master' (refers to commit 'c')
既然checkout是修改HEAD,所以可以出现下面的情况:
HEAD (refers to commit 'b')
|
v
a---b---c branch 'master' (refers to commit 'c')
HEAD指向b,用git branch看看有几个分支:
×HEAD detached from b
master
发现有两个分支,可是我们没有创建除了master以外的任何分支啊~
可以把HEAD detached from b理解为一个临时的分支,并且这时候HEAD指针是游离普通分支之外的。
在这个临时分支上可以进行git的一切操作:add commit 等等,像这样:
HEAD (refers to commit 'f')
|
v
e---f
/
a---b---c branch 'master' (refers to commit 'c')
假如远程库中有一个master分支,一个用来开发的develop分支,这时候如果我们要向远程库推送,会发现无法推送。
因为HEAD不知道要把内容推送到哪个远程分支上去。
那么问题来了,怎么把修改的内容提交到远程库呢?
由于本地没有develop分支,所以需要先这样:
git fetch origin develop:develop
在本地创建一个develop分支,并且把它和远程develop关联起来。现在再看看本地有哪些分支:
git branch ×develop
master
刚才的HEAD detached from b分支消失了! 在这个分支下修改的内容也不见了!
没关系,进行下一步。
git reflog show HEAD@{now} -
这个命令会把HEAD指针所有的动作显示出来。从中可以清楚的看到,在指针中提交对应的commit id
找到需要恢复的commit ,记下前面的commit id
git branch temp efa64f5
新建一个名字叫temp的分支,用这个分支代替之前的临时分支并且拥有想要恢复的commit,现在切换到temp下会发现一切都回来了
但是还是不能推送啊。原因是temp是我们本地的分支,远程库中并没有这个分支。
git checkout develop
切换到从远程库拉取到的develop分支
git merge temp
将temp分支合并到develop分支上,有冲突就解决冲突。
最后:
git push origin develop
OK,推送到远程库。
HEAD DETACHED push origin失败问题的更多相关文章
- git push origin master 上传失败
http://blog.csdn.net/llf369477769/article/details/51917557 按照网上教程用git把项目上传到github,但是在最后一步git push or ...
- git status: HEAD detached from origin/master问题的解决
问题:执行git status,提示: HEAD detached from origin/master 原因:分支选错了,后续的提交都提交到了一个匿名分支之上,整个状态是游离了的 解决方法: 1.查 ...
- git push origin master、git pull出现如下错误
git push origin master出现如下错误: Counting objects: , done. Writing objects: % (/), bytes, done. Total ( ...
- git push origin与git push -u origin master的区别
$ git push origin 上面命令表示,将当前分支推送到origin主机的对应分支. 如果当前分支只有一个追踪分支,那么主机名都可以省略. $ git push 如果当前分支与多个主机存在追 ...
- git HEAD detached from origin 问题的解决
这个问题是因为分支选错了,所以说后续的提交都提交到了一个匿名分支之上,整个状态是游离了的 下面说一下我解决问题的步骤 1.查看在游离状态下提交的最新commit号 git branch -v 2.创建 ...
- git push origin master出错:error: failed to push some refs to
1.输入git push origin master 出错:error: failed to push some refs to 那是因为本地没有update到最新版本的项目(git上有README. ...
- git push origin master和git push有什么区别?
1.master是主分支,还可以建一些其他的分支用于开发.2.git push origin master的意思就是上传本地当前分支代码到master分支.git push是上传本地所有分支代码到远程 ...
- git push origin master:master
$git push origin master:master (在local repository中找到名字为master的branch,使用它去更新remote repository下名字为mast ...
- git push origin master错误
以下错误是因为远程有的文件,本地没有,故而无法push文件到远程 $ git push origin master To git@github.com:AntonioSu/learngitWindow ...
随机推荐
- 【洛谷】CYJian的水题大赛 解题报告
点此进入比赛 \(T1\):八百标兵奔北坡 这应该是一道较水的送分题吧. 理论上来说,正解应该是DP.但是,.前缀和优化暴力就能过. 放上我比赛时打的暴力代码吧(\(hl666\)大佬说这种做法的均摊 ...
- Deep Learning 优化方法总结
Stochastic Gradient Descent (SGD) SGD的参数 在使用随机梯度下降(SGD)的学习方法时,一般来说有以下几个可供调节的参数: Learning Rate 学习率 We ...
- 查看电脑是否安装node.js
打开命令行
- Python小脚本程序
本文旨在搜集最简单最原子性的代码块,简单清晰容易阅读,然后由用户自己组合.Python代码排版请自行修改. 这里是索引目录: 1. 下载网站文件 2. 下载网站多个文件 1. 下载网站文件 impor ...
- eclipse中关闭java文件后再打开,找不到如何切换可视化编辑器
http://www.iteye.com/problems/64806 两种方式: 第一种正如楼上的老兄说的.在该java类中,鼠标右击,移动到openWith上 找到jigloo,找不到就在ot ...
- Bootstrap 历练实例 - 折叠(Collapse)插件方法
方法 下面是一些折叠(Collapse)插件中有用的方法: 方法 描述 实例 Options:.collapse(options) 激活内容为可折叠元素.接受一个可选的 options 对象. $(' ...
- SummerVocation_Learning--java的String类运用
题目: 编写一个程序,输出一个字符串中的大写字母数,小写字母数,及其它字母数. 思路1: 可以先遍历整个字符串,在判断每个字符的类型. public class TestString { public ...
- STL之deque用法
deque:双端队列 底层是一个双向链表. 常用的有队列的尾部入队.首部出队. 普通队列:queuequeue 模板类的定义在<queue>头文件中.与stack 模板类很相似,queue ...
- Apache 配置默认编码
找到apache配置文件 httpd.conf ,找到以下内容 # # Specify a default charset for all content served; this enables # ...
- ASP.NET Core模块化前后端分离快速开发框架介绍之2、快速创建一个业务模块
源码地址 GitHub:https://github.com/iamoldli/NetModular 演示地址 地址:https://nm.iamoldli.com 账户:admin 密码:admin ...