我知道如何创建跟踪远程分支的新分支,但如何使现有分支跟踪远程分支?

我知道我可以编辑.git/config文件,但似乎应该有一种更简单的方法。


当前回答

我相信,早在Git1.5.x中,您就可以让本地分支$branch跟踪远程分支源/$BRANCCH,就像这样。

鉴于$BRANCH和origin/$BRANCCH存在,并且您当前尚未签出$BRANCH(如果有,请切换),请执行以下操作:

git branch -f --track $BRANCH origin/$BRANCH

这将重新创建$BRANCH作为跟踪分支。尽管$BRANCH已经存在,但-f强制创建--如果使用了通常的默认值(即git-config参数branch.atosetupmerge为true),则跟踪是可选的。

注意,如果origin/$BRANCH还不存在,您可以通过将本地$BRANCCH推入远程存储库来创建它,方法是:

git push origin $BRANCH

然后是上一个命令,将本地分支提升为跟踪分支。

其他回答

使用“--track”选项

在一次git拉动后:git checkout--track<远程分支名称>或:git获取和git签出<分支名称>

这也行

git branch --set-upstream-to=/< remote>/< branch> < localbranch>

对于像我这样只想将本地分支名称与远程分支名称同步的任何人,这里有一个方便的命令:

git branch -u origin/$(git rev-parse --abbrev-ref HEAD)

对于Git 1.8.0及更高版本:

实际上,对于公认的工作答案:

git remote add upstream <remote-url>
git fetch upstream
git branch -f --track qa upstream/qa
# OR Git version 1.8.0 and higher:
git branch --set-upstream-to=upstream/qa
# Gitversions lower than 1.8.0
git branch --set-upstream qa upstream/qa

对于git版本2.25.1,请使用以下命令:

git push --set-upstream origin <local_branch_name>