如何停止跟踪Git中的远程分支?

我要求停止跟踪,因为在我的具体情况下,我想删除本地分支,但不是远程分支。删除本地分支并将删除推到remote也会删除远程分支:

如何在本地和GitHub中删除Git分支?

我能不能只做git branch -d the_branch,当我之后推送git时,它不会被传播?

如果我稍后运行git push origin:the_branch,它是否只会传播?


当前回答

Git分支——unset-upstream停止跟踪所有本地分支,这是不可取的。

从.git/config文件中删除[branch "branch-name"]段

git branch -D 'branch-name' && git branch -D -r 'origin/branch-name'

这对我来说是最好的。

其他回答

这不是问题的答案,但我不知道如何在上面的评论中获得体面的代码格式…因此,我的评论是自动降低声誉。

在我的.gitconfig中,我有@Dobes在一个花哨的shmancy[别名]条目中提交的食谱:

# to untrack a local branch when I can't remember 'git config --unset'
cbr = "!f(){ git symbolic-ref -q HEAD 2>/dev/null | sed -e 's|refs/heads/||'; }; f"
bruntrack = "!f(){ br=${1:-`git cbr`};  \
    rm=`git config --get branch.$br.remote`; \
    tr=`git config --get branch.$br.merge`; \
    [ $rm:$tr = : ] && echo \"# untrack: not a tracking branch: $br\" && return 1; \
    git config --unset branch.$br.remote; git config --unset branch.$br.merge; \
    echo \"# untrack: branch $br no longer tracking $rm:$tr\"; return 0; }; f"

然后我就可以跑了

$ git bruntrack branchname

要移除当前分支的上游,请执行以下操作:

$ git branch --unset-upstream

这可用于Git v.1.8.0或更新版本。(来源:1.7.9 ref, 1.8.0 ref)

正如Yoshua Wuyts的回答中提到的,使用git分支:

git branch --unset-upstream

其他选项:

您不必删除本地分支。

简单地删除跟踪远程分支的本地分支:

git branch -d -r origin/<remote branch name>

-r,——remotes告诉git删除远程跟踪分支(即删除跟踪远程分支的分支集)。这将不会删除远程回购上的分支!

参见“很难理解git-fetch”

没有本地跟踪分支的概念,只有远程跟踪分支。 因此,origin/master是在origin repo中对master的远程跟踪分支

正如Dobes Vandermeer的回答中提到的,您还需要重置与本地分支相关的配置:

git config --unset branch.<branch>.remote
git config --unset branch.<branch>.merge

删除<branchname>的上游信息。 如果没有指定分支,则默认为当前分支。

(git 1.8+, 2012年10月,提交b84869e由Carlos Martín Nieto (carlosmn))

这将使任何推/拉完全不知道origin/<远程分支名称>。

您可以使用这种方式删除远程分支

git remote remove <your remote branch name>

删除本地分支和远程分支之间的关联:

git config --unset branch.<local-branch-name>.remote
git config --unset branch.<local-branch-name>.merge

如果你不需要,可以选择删除本地分支:

git branch -d <branch>

这不会删除远程分支。