git - 想要一次拉所有远程分支.. 但是 git branch -r 只显示一些分支而不是 GitHub 中的 109 个远程分支
问题描述
我从 GitHub 克隆了一个远程存储库,这不是我的。当我执行git branch --all
或git branch -r
它显示一些分支而不是 109 个分支时。fetch --all
当我使用 git和git pull --all
命令时,也会发生同样的事情。这些命令不会获取所有远程分支并将其拉入我的本地存储库。执行git remote show origin
时显示所有远程分支。我想一次拉出所有远程分支。我还为 git bash 使用了一个线性命令,但也无法正常工作。谁能帮帮我吗?
解决方案
这里的--all
标志表示所有遥控器。仅当您拥有多个遥控器时才有意义(例如,初始origin
加上您后来添加的名为upstream
or的遥控器repo2
)。
任何克隆的默认设置是复制所有提交,根本不复制任何分支,因为复制分支通常没有用。如果您确实复制了分支,您通常最终会负责更新它们。这既没有必要也没有乐趣,因此默认不复制任何分支。相反,正常的设置是获取一些其他 Git 的分支名称,并将它们转换为您自己的克隆中的远程跟踪名称。随后git fetch
会自动更新所有远程跟踪名称,因此您根本不需要任何分支。
请注意,git fetch
默认为从一个遥控器获取。例如,如果您在分支上nurul
(见下文)并将其上游设置为origin/nurul
,这将仅从 获取origin
。如果您已将其上游设置为repo2/nurul
,则它将仅从 获取repo2
。(分支的上游通常是您自己的存储库中的远程跟踪名称,它对应于另一个 Git 存储库中的分支名称。)如果您想更新所有名称,origin/*
现在是有意义的。repo2/*
git fetch --all
如果您希望在您的存储库中创建自己的新提交,无论出于何种目的——可能包括将这些新提交发送到其他 Git 存储库——<em>只有这样,在您自己的存储库中创建一些或多个分支才有意义. 该git clone
命令假定您可能确实想在自己的存储库中创建一 (1) 个新分支,并将使用您提供-b
给git clone
.
分支名称必须选择某个提交。在创建自己的新分支时,要选择的提交有时与其他 Git 存储库中由某个分支名称命名的提交相同。例如,也许您可以克隆您同事的存储库,该存储库为每个同事提供一个分支,外加一个名为develop
. 每个同事的分支名称选择的提交不是很重要,除非其中一个是您想要开始的提交,在这种情况下,您可以使用-b coworker3
或任何合适的在这里。但是,如果名称选择的提交develop
是最合适的,您可以-b develop
在此处使用。
无论如何,既然您有一个带有一个分支的克隆,下一步可能是重命名您的分支nurul
,使用git branch -m nurul
. 现在,您的一个分支上有您的名字,这样您就不会将它与您根据其他人的提交创建的任何分支混为一谈,如果您想在他们的提交之后添加一个提交。
您和您的同事或同事将使用的实际工作流程取决于您,但创建分支几乎没有意义,除非您计划向该分支添加提交。
推荐阅读
- ios - IOS 未通过 fcm 接收 Firebase 通知,但仅在 ANDROID 上
- json - JSON中嵌套数组的输出
- javascript - 如何在 .map 中发表声明以制作?
- c# - TCP 连接中的套接字异常 10049
- angular - 在破坏路由的 URL 中使用 %2F 的角度路由
- javascript - 为什么 bootstrap-table 中的 showButtonIcons 不起作用
- laravel - 需要处理 Laravel 异常和记录细节不匹配错误
- java - Assertion with Hashmap - 使用 java 的 testng 验证 selenium webdriver 中的实际和预期数据
- c++ - 使用 lambda 作为参数时无法转换模板
- dolibarr - 如何在 dolibarr 13.0.1 中开发模块