如何解决想要一次拉出所有远程分支..但是 git branch -r 只显示一些分支而不是 GitHub 中的 109 个远程分支
我从 GitHub 克隆了一个远程存储库,它不是我的。当我执行 git branch --all
或 git branch -r
时,它会显示一些分支而不是 109 个分支。当我使用 git fetch --all
和 git pull --all
命令时会发生同样的事情。这些命令不会将所有远程分支提取并拉入我的本地存储库。执行 git remote show origin
时显示所有远程分支。我想一次拉出所有远程分支。我还为 git bash 使用了一个 liner 命令,但也不起作用。
有人可以帮我吗?
解决方法
此处的 --all
标志表示所有遥控器。仅当您有多个遥控器时才有意义(例如,最初的 origin
加上您后来添加的名为 upstream
或 repo2
的遥控器)。
任何克隆的默认设置是复制所有提交并且根本没有分支,因为复制分支通常没有用。如果您确实复制分支,您通常最终要负责更新它们。这既没有必要也没有乐趣,因此默认复制 no 分支。相反,正常的设置是采用一些其他 Git 的分支名称,并将它们转换为您自己的克隆中的远程跟踪名称。随后的 git fetch
会自动更新所有远程跟踪名称,因此您根本不需要任何分支。
请注意,git fetch
默认从 one 远程获取。例如,如果您在分支 nurul
(见下文)上并将其上游设置为 origin/nurul
,这将仅从 origin
获取。如果您已将其上游设置为 repo2/nurul
,则只会从 repo2
获取。 (分支的上游通常是您自己的存储库中的远程跟踪名称,对应于另一个 Git 存储库中的分支名称。)如果您想更新所有 origin/*
和 repo2/*
名称,现在 git fetch --all
是有道理的。
如果您希望在您的存储库中创建自己的新提交,无论出于何种目的——可能包括将这些新提交发送到其他 Git 存储库——然后才在您自己的存储库中创建一个或多个分支是否有意义。 git clone
命令假定您可能确实想在自己的存储库中创建一 (1) 个新分支,并将使用您提供给 -b
的 git clone
参数的名称来实现。
分支名称必须选择一些提交。在创建自己的新分支时,要选择的提交有时与由其他 Git 存储库中的某个分支名称命名的提交相同。例如,您可能会克隆同事的存储库,其中每个同事都有一个分支,另外还有一个名为 develop
的分支。每个同事的分支名称选择的提交不是很重要除非其中之一是您想要开始的提交,在这种情况下,您可以使用 -b coworker3
或其他这里很合适。不过,如果名称为 develop
的提交是最合适的,您可以在此处使用 -b develop
。
无论如何,既然您有一个带有一个分支的克隆,下一步可能是使用 nurul
重命名您的分支 git branch -m nurul
。现在您的一个分支上有您的名称,这样您就不会将它与您根据其他人的提交创建的任何分支混淆,如果您想在他们提交之后添加一个提交。
您和您的同事或同事将使用的实际工作流程取决于您,但创建分支几乎没有意义,除非您计划向该分支添加提交。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。