中央存储库必须设置在一个新的服务器上,所以我在本地回购上创建了一个新的远程存储库,并将其推送到该服务器上。

但现在当我做git拉,它声称我是最新的。这是错误的——它告诉我的是旧的远程分支,而不是新分支,我知道新分支实际上有新的提交要获取。

如何更改本地分支以跟踪不同的远程?

我可以在git配置文件中看到这一点,但我不想把事情搞砸。

[branch "master"]
    remote = oldserver
    merge = refs/heads/master

当前回答

对我来说,解决办法是:

git remote set-url origin https://some_url/some_repo

然后:

git push

其他回答

如果你头脑清醒的话,编辑配置文件是很安全的。如果你想要更偏执一点,你可以使用瓷器命令来修改它:

git config branch.master.remote newserver

当然,如果您查看之前和之后的配置,您将看到它完全按照您要做的做了。

但在你的个人情况下,我要做的是:

git remote rename origin old-origin
git remote rename new-origin origin

也就是说,如果新服务器将成为规范的远程服务器,为什么不将其称为origin,就像您最初从它克隆出来一样?

你可以删除你当前的分支,然后这样做:

git branch --track local_branch remote_branch

或者在配置中将远程服务器更改为当前服务器

对于最新的git(2.5.5),命令如下:

git branch --set-upstream-to=origin/branch

这将更新当前本地分支的远程跟踪分支

最简单的方法是简单地推到新的分支:

Git push -u origin branch/name

经过上面的尝试和搜索,搜索等。我意识到我的任何更改都没有在本地分支的服务器上,并且Team Explorer中的Visual Studio没有指示该分支跟踪远程分支。远程分支在那里,所以它应该工作。我最终删除了github上的远程分支,并're'推送我的本地分支,其中有我的更改,由于未知的原因没有被跟踪。

通过删除远程分支并're' Push未被跟踪的本地分支,本地分支将在git hub上重新创建。我尝试在命令提示符(使用Windows),我不能让我的本地分支跟踪远程分支,直到我这样做。一切都恢复正常了。