- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我设置了一个分支来跟踪原始引用。 git checkout <branchname>
切换到那个分支,并且一个 git status
会告诉我我的分支离原点有多远,但令我惊讶的是 origin/HEAD
仍然指向 origin/master
,而不是 origin/<branchname>
所以我的问题是,在什么情况下 origin/HEAD 会移动?
编辑:
我很欣赏有关如何移动 origin/HEAD 的答案,但我对“有机地”移动它的原因很感兴趣,除了我明确告诉它这样做之外。
例如,当我切换分支时,git 将 HEAD 指向我正在 check out 的分支,所以我很惊讶 origin/HEAD 没有以相同的方式移动。
最佳答案
首先请注意,您的问题显示出一些误解。 origin/HEAD 表示远程上的默认分支,即您调用 origin 的远程存储库中的 HEAD。当您在 repo 协议(protocol)中切换分支时,您不会影响它。远程分支也是如此;你的 repo 中可能有 master
和 origin/master
,其中 origin/master
代表 master
的本地副本> 远程存储库中的分支。
origin 的 HEAD 只有在您或其他人在远程存储库中实际更改它时才会更改,这基本上永远不会发生 - 您希望默认分支和公共(public)存储库在稳定分支上保持不变(可能是大师)。 origin/HEAD 是一个本地引用,表示远程存储库中 HEAD 的本地副本。(其全称是 refs/remotes/origin/HEAD。)
我认为上面的内容回答了您真正想知道的内容,但是继续回答您明确提出的问题... origin/HEAD 在您克隆存储库时自动设置,仅此而已。奇怪的是,它不是由 git remote update
之类的命令设置 - 我相信它会改变的唯一方法是手动更改它。 (我所说的更改是指指向不同的分支;显然,如果该分支发生更改,则提交指向更改,这可能发生在获取/pull/远程更新时。)
编辑:下面讨论的问题已在 Git 1.8.4.3 中得到纠正;见this update .
不过,有一个小警告。 HEAD 是一个符号引用,指向一个分支而不是直接指向一个提交,但是 git 远程传输协议(protocol)只报告引用的提交。所以 Git 知道 HEAD 和所有其他引用指向的提交的 SHA1;然后它必须通过找到指向同一提交的分支来推断 HEAD 的值。这意味着如果两个分支碰巧指向那里,它是不明确的。 (我相信它会尽可能选择 master,然后按字母顺序回退到第一个。)你会在 git remote show origin
的输出中看到这个报告:
$ git remote show origin
* remote origin
Fetch URL: ...
Push URL: ...
HEAD branch (remote HEAD is ambiguous, may be one of the following):
foo
master
奇怪的是,虽然以这种方式打印的 HEAD 的概念会随着远程上的事情发生变化而改变(例如,如果 foo 被删除),它实际上并没有更新 refs/remotes/origin/HEAD
。这可能会导致非常奇怪的情况。假设在上面的示例中 origin/HEAD 实际上指向 foo,然后 origin 的 foo 分支被删除。然后我们可以这样做:
$ git remote show origin
...
HEAD branch: master
$ git symbolic-ref refs/remotes/origin/HEAD
refs/remotes/origin/foo
$ git remote update --prune origin
Fetching origin
x [deleted] (none) -> origin/foo
(refs/remotes/origin/HEAD has become dangling)
所以即使 remote show 知道 HEAD 是 master,它也不会更新任何东西。陈旧的 foo 分支被正确修剪,HEAD 变得悬空(指向一个不存在的分支),并且它仍然不会更新它以指向 master。如果你想解决这个问题,使用 git remote set-head origin -a
,它会像上面那样自动确定 origin 的 HEAD,然后实际设置 origin/HEAD 以指向适当的远程分支。
关于git - origin/HEAD 是如何设置的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8839958/
XMLHttpRequest cannot load http://localhost:8080/api/test. Origin http://localhost:3000 is not allow
Git diff 似乎在比较时返回不同的变化: git diff origin/master ... origin/branch git diff origin/master...origin/bra
我正在研究 3.1 Git Branching - Branches in a Nutshell 中的 git 分支概念 我正在玩虚拟存储库。 git log --oneline --decorate
我知道有很多类似的问题,唯一的区别是我从 **same ** 域提供的两个页面得到了这个。这可以在下面的示例中看到。 Uncaught DOMException: Blocked a fram
我被要求使用 Fork Workflow,即我必须处理具有相同或相似名称的多个分支。我为什么要使用这些不同的变体? 以下是不同命名约定的一些示例: 我的分支机构 起源我的分支 起源/我的分支机构 远程
这个问题已经有答案了: How do I delete a Git branch locally and remotely? (41 个回答) 已关闭 9 年前。 好的,我已经创建了一个 origin
这是我关于如何让 lerna 在 Jenkins 中运行的一系列问题的一部分。 上一期: lerna publish on Jenkins "git remote update" Fails "Cou
当我尝试从我的 Angular 6 应用程序访问 Webhdfs 时,我收到如下所示的错误。在我看来,我几乎尝试了所有方法,包括更改 core-site.xml 和 hdfs-site.xml 中的设
我正在从不同的来源向我的服务器发出 Ajax POST 请求以供用户登录。我已经在我的 application_controller.rb 中正确设置了 Cross Origin header : d
我刚刚克隆了一个存储库并在 Git 中开始了一个新分支。我已经这样做了很多次而没有遇到问题。今晚当我尝试使用 git branch --set-upstream develop origin/deve
我对 Git 还很陌生,但仍在掌握它的窍门。我最近才开始使用分支机构,遇到了一些问题。 我有两个开发系统,一个 Ubuntu 桌面和一个 MacBookPro。我在 Ubuntu 系统上的一个新的 o
这个问题在这里已经有了答案: Why does "git push main" work on GitHub when "git push master" does not? Also what i
我想从我的应用访问一个 API。 curl 请求是: curl --request POST https://... --header 'Authorization: Token ...'
我试图理解的遗留 makefile 具有 -Wl,-z,origin,-rpath,'$ORIGIN/../lib' 好的,我看到 -Wl 表示以下是链接器选项;逗号将替换为空格。 GNU ld 的联
我正在寻找 OpenShift Origin 和 OpenShift Enterprise 之间的主要区别。我知道第一个是开源的,后者是商业版。与开源版本相比,OpenShift Enterprise
我在 Sourcetree 中有这个历史图表: Sourcetree graph 如何将最后一次提交从 origin/development 复制到 origin/master 分支? 第二个问题:图
运行 git 命令时空格和斜杠有什么区别? 我有时会看到 git push origin master(这是一个空格) 还有其他时候我看到 git rebase origin/master(使用斜杠)
根据文档,git pull 执行 git fetch 然后执行 git merge,但是在那种情况下执行 git pull origin master 应该执行 git fetch origin ma
我正在使用我的 git 存储库,并在早些时候对 master 分支进行了相当多的提交。现在我意识到它有点太吵了,我想将所有这些 merge 到一个提交中。 102381 commit z .... 1
我制作了一个小的 xslt 文件来创建一个名为 weather.xsl 的 html 输出,代码如下: 我想将 html 输出加载到 html 文件中的 div 中,我正在尝试
我是一名优秀的程序员,十分优秀!