远程存储库包含各种分支,如origin/davis_branch:
$ git branch -r
origin/HEAD -> origin/master
origin/daves_branch
origin/master
如何将daves_branch获取到本地存储库,以便它跟踪origin/davis_branch?
我尝试了:
$ git fetch origin discover
$ git checkout discover
远程存储库包含各种分支,如origin/davis_branch:
$ git branch -r
origin/HEAD -> origin/master
origin/daves_branch
origin/master
如何将daves_branch获取到本地存储库,以便它跟踪origin/davis_branch?
我尝试了:
$ git fetch origin discover
$ git checkout discover
当前回答
git fetch&&git checkout<你朋友的分行名>应该可以做到这一点
其他回答
如果你已经知道你的远程分支了。。。
git remote
=> One
=> Two
并且您知道要签出的分支名称,例如br1.2.3.4,然后执行
git fetch One
=> returns all meta data of remote, that is, the branch name in question.
剩下的就是结账
git checkout br.1.2.3.4
然后用它做新的树枝。
如果您正在尝试“签出”一个新的远程分支(仅存在于远程,而不存在于本地),以下是您需要的:
git fetch origin
git checkout --track origin/<remote_branch_name>
这假设您要从原点提取。如果没有,请用远程名称替换源。
Use:
git checkout -b serverfix origin/serverfix
这是一个非常常见的操作,Git提供了--track速记:
git checkout --track origin/serverfix
事实上,这是如此普遍,甚至有一条捷径。如果您尝试签出的分支名称(a)不存在,并且(b)仅与一个远程服务器上的名称完全匹配,Git将为您创建一个跟踪分支:
git checkout serverfix
要使用与远程分支不同的名称设置本地分支,可以轻松地使用具有不同本地分支名称的第一个版本:
git checkout -b sf origin/serverfix
现在,您的本地分支sf将自动从origin/serverfix中提取。
来源:Pro Git,第二版,由Scott Chacon和Ben Straub撰写(为便于阅读而删减)
有时,你被要求不要摆弄主分支,只在远程分支工作(正如我被要求的那样)。所以你只需要远程分支。
因此,要单独克隆远程分支(没有主分支),请执行以下操作
git clone url --branch remote_branch_name
哪里remote_branch_name是远程分支的名称
例如
git clone git://git.kernel.org/pub/scm/linux/kernel/git/stable/linux-stable.git --branch v3.15
这将确保您使用远程分支的名称将远程分支克隆到本地分支。
现在,如果您提交代码并推送,代码将单独提交给该分支。
[快速回答]
有很多选择,我最喜欢的是:
-备选方案1:
git fetch --all
git checkout YourBranch
使用此替代方法时,请使用远程存在但不在本地的分支。
-备选方案2:
git checkout -b 'YourBranch' origin/'YourRemote'
也许,这是最简单的方法。