首页 > 解决方案 > 想要一次拉所有远程分支.. 但是 git branch -r 只显示一些分支而不是 GitHub 中的 109 个远程分支

问题描述

我从 GitHub 克隆了一个远程存储库,这不是我的。当我执行git branch --allgit branch -r它显示一些分支而不是 109 个分支时。fetch --all当我使用 git和git pull --all命令时,也会发生同样的事情。这些命令不会获取所有远程分支并将其拉入我的本地存储库。执行git remote show origin时显示所有远程分支。我想一次拉出所有远程分支。我还为 git bash 使用了一个线性命令,但也无法正常工作。谁能帮帮我吗?

标签: gitgithub

解决方案


这里的--all标志表示所有遥控器。仅当您拥有多个遥控器时才有意义(例如,初始origin加上您后来添加的名为upstreamor的遥控器repo2)。

任何克隆的默认设置是复制所有提交,根本不复制任何分支,因为复制分支通常没有用。如果您确实复制了分支,您通常最终会负责更新它们。这既没有必要也没有乐趣,因此默认不复制任何分支。相反,正常的设置是获取一些其他 Git 的分支名称,并将它们转换为您自己的克隆中的远程跟踪名称。随后git fetch会自动更新所有远程跟踪名称,因此您根本不需要任何分支。

请注意,git fetch默认为从一个遥控器获取。例如,如果您在分支上nurul(见下文)并将其上游设置为origin/nurul,这将仅从 获取origin。如果您已将其上游设置为repo2/nurul,则它将仅从 获取repo2。(分支的上游通常是您自己的存储库中的远程跟踪名称,它对应于另一个 Git 存储库中的分支名称。)如果您想更新所有名称,origin/* 现在有意义的。repo2/* git fetch --all

如果您希望在您的存储库中创建自己的新提交,无论出于何种目的——可能包括将这些新提交发送到其他 Git 存储库——<em>只有这样,在您自己的存储库中创建一些或多个分支才有意义. 该git clone命令假定您可能确实想在自己的存储库中创建一 (1) 个新分支,并将使用您提供-bgit clone.

分支名称必须选择某个提交。在创建自己的新分支时,要选择的提交有时与其他 Git 存储库中由某个分支名称命名的提交相同。例如,也许您可​​以克隆您同事的存储库,该存储库为每个同事提供一个分支,外加一个名为develop. 每个同事的分支名称选择的提交不是很重要,除非其中一个是您想要开始的提交,在这种情况下,您可以使用-b coworker3或任何合适的在这里。但是,如果名称选择的提交develop是最合适的,您可以-b develop在此处使用。

无论如何,既然您有一个带有一个分支的克隆,下一步可能是重命名您的分支nurul,使用git branch -m nurul. 现在,您的一个分支上有您的名字,这样您就不会将它与您根据其他人的提交创建的任何分支混为一谈,如果您想在他们的提交之后添加一个提交。

您和您的同事或同事将使用的实际工作流程取决于您,但创建分支几乎没有意义,除非您计划向该分支添加提交


推荐阅读