5

我最终得到了一个处于我不知道如何处理的状态的 git 存储库,我需要一些帮助来理解 a) 发生了什么,存储库如何以及为什么处于这种状态,以及 b) 我应该如何反应给它。基本上,当从遥控器拉出时,我最终会领先于遥控器,即使我重置所有更改并重试。

这就是我所做的:

我已经分叉了一个 git 存储库,克隆了上游版本(我没有写入权限),然后将我自己的 fork 添加到远程列表中,因此git remote -v显示以下内容:

$ git remote -v
mine    git@github.com:tlycken/julia.git (fetch)
mine    git@github.com:tlycken/julia.git (push)
origin  git://github.com/JuliaLang/julia.git (fetch)
origin  git://github.com/JuliaLang/julia.git (push)

我现在想确保我的本地版本与上游仓库中的所有内容都是最新的,所以我运行

$ git pull origin master
From git://github.com/JuliaLang/julia
 * branch            master     -> FETCH_HEAD
Already up-to-date.
tlycken$ git status
# On branch master
# Your branch is ahead of 'origin/master' by 4 commits.
#   (use "git push" to publish your local commits)
#
nothing to commit, working directory clean

这让我很困惑。为什么我的分支在 origin master 之前?我没有改变任何东西。

为了看看我能不能做点什么,我跑了git lggit log --graph一些漂亮打印的别名)。输出的顶部如下所示:

*   6912a42 - (HEAD, mine/master, master) Merge pull request #3052 from daviddelaat/linalgnumber (2013-05-10 11:23:09 -0700) <Viral B. Shah>
|\  
| * 8116d51 - Use Number instead of Integer in some linalg operations (2013-05-10 19:12:45 +0200) <David de Laat>
* | 6cc1532 - Update .travis.yml configuration in the manual. (2013-05-10 21:41:59 +0530) <Viral B. Shah>
* | fa1e3fe - Update logdet. Close #3070. (2013-05-10 19:35:37 +0530) <Viral B. Shah>
* |   a182f7f - (origin/master, origin/HEAD, mine/contrib-base) Merge branch 'master' of github.com:JuliaLang/julia (2013-05-10 03:10:38 -0400) <Jeff Bezanson>

显然,HEAD处于不同的位置。为了确保在开始分支之前在本地存储库中获得正确的代码,我确实git reset --hard origin/HEAD删除了前面的所有内容,然后git pull origin master确保我是最新的(即没有重置太远或其他什么):

$ git pull origin master
From git://github.com/JuliaLang/julia
 * branch            master     -> FETCH_HEAD
Updating a182f7f..6912a42
Fast-forward
 base/linalg/dense.jl         |  2 +-
 base/linalg/factorization.jl | 44 ++++++++++++++++++++++----------------------
 doc/manual/packages.rst      |  3 +--
 3 files changed, 24 insertions(+), 25 deletions(-)
$ git status
# On branch master
# Your branch is ahead of 'origin/master' by 4 commits.
#   (use "git push" to publish your local commits)
#
nothing to commit, working directory clean

我又回到了我开始的地方。

这里发生了什么?我应该怎么做才能使我的本地 master 拥有来自上游的最新更新?

4

1 回答 1

11

git pull不会更新跟踪origin/各种遥控器所在位置的跟踪参考 (...) HEAD

运行git fetch origin,它会更新所有的origin/... 跟踪参考,并且git status不再认为你领先。


git pull <remote> <branch>相当于:

  1. git fetch <remote> <branch>:FETCH_HEAD
  2. git merge FETCH_HEAD

因为它仅明确指定要获取的一个分支,并将其提取到特殊的本地 refFETCH_HEAD中,所以它不会在本地更新任何其他内容 - 仅更新FETCH_HEAD您要进入的分支。

相反,运行git fetch <remote>将更新与该远程存储库关联的所有引用。

于 2013-05-11T02:06:00.510 回答