一、查看追踪关系
查看当前远程仓库信息
git remote -vv
查看分支与远程分支追踪状态
git branch -vv
二、修改本地‘master’分支的追踪分支操作
原先对应远程分支是master,我们要修改为远程dev分支。
1. 进入当前项目根目录的’.git’文件夹。打开config文件。
2. [remote "origin"]这一项是修改对应远程Git仓库地址。
3. [branch "master"]这一项是修改本地分支‘master’的远程追踪关系分支,直接修改merge = refs/heads/master为merge = refs/heads/dev
4. 再次通过命令行查看状态就可以发现你的远程分支已经改掉。
5. 可能出现的问题:
没有[branch "master"]这一项怎么办?
如果是新项目,没有git pull或git clone,就不会与远程分支建立关系,或者也可以自己添加这一项,但不建议。
三、建立追踪关系
1. 手动建立追踪关系
$ git branch --set-upstream-to=<远程主机名>/<远程分支名> <本地分支名>
2. push时建立追踪关系
$ git push -u <远程主机名> <本地分支名>
加上-u参数,这样push时,本地指定分支就和远程主机的同名分支建立追踪关系。
3. 新建分支时建立跟踪关系
$ git checkout -b <本地分支名> <远程主机名>/<远程分支名>
新分支指针指向 <远程主机名>/<远程分支名> 所指的位置。具体位置可用 git log --oneline --graph 查看。
注意:
使用 1 和 3 命令前要先确保本地有名为 <远程主机名>/<远程分支名> 的远程跟踪分支,没有就要先用 git fetch 或 git pull 命令从远程主机上抓取,抓取后自动产生。远程跟踪分支是远程分支状态的引用, 它们是你不能移动的本地引用。用 git branch 看不到,用 git branch -r 才可以看到。