跳至主要内容

Fork 存储库

分支是新的存储库,它与原始的“上游”存储库共享代码和可见性设置。

平台导航

关于分支

分支是新的存储库,它与原始的“上游”存储库共享代码和可见性设置。分支通常用于在将想法或更改提议回上游存储库之前进行迭代,例如在开源项目中或当用户无权访问上游存储库时。有关更多信息,请参阅“使用分支”。

向其他人的项目提议更改

例如,您可以使用分支来提议与修复错误相关的更改。与其记录您发现的错误的问题,您可以

  • Fork 存储库。
  • 进行修复。
  • 向项目所有者提交拉取请求。

将其他人的项目用作您自己想法的起点。

开源软件基于这样一个理念:通过共享代码,我们可以创建更好、更可靠的软件。有关更多信息,请参阅开源计划上的“关于开源计划”。

有关将开源原则应用于您组织在 GitHub 上的开发工作的更多信息,请参阅 GitHub 的白皮书“内部源简介”。

从他人项目的 Fork 创建公共存储库时,请确保包含许可证文件,该文件确定您希望如何与他人共享您的项目。有关更多信息,请参阅 choosealicense.com 上的“选择开源许可证”。

有关开源的更多信息,特别是如何创建和发展开源项目,我们创建了开源指南,这些指南将通过推荐创建和维护开源项目存储库的最佳实践来帮助您培养健康的开源社区。您还可以参加关于维护开源社区的免费GitHub 技能课程。

先决条件

如果您尚未设置,请先从 Git 设置 Git 和对 GitHub.com 的身份验证。有关更多信息,请参阅“设置 Git”。

Fork 存储库

您可能需要 fork 一个项目来建议对上游存储库进行更改。在这种情况下,定期将您的 fork 与上游存储库同步是一个好习惯。为此,您需要在命令行上使用 Git。您可以使用刚刚 fork 的同一个 octocat/Spoon-Knife 存储库来练习设置上游存储库。

  1. 在 GitHub 上,导航到 octocat/Spoon-Knife 存储库。

  2. 在页面右上角,点击Fork

    Screenshot of the main page of repository. A button, labeled with a fork icon and "Fork 59.3k," is outlined in dark orange.

  3. 在“所有者”下,选择下拉菜单并点击分叉存储库的所有者。

  4. 默认情况下,fork 的名称与其上游存储库相同。或者,为了进一步区分您的 fork,在“存储库名称”字段中输入一个名称。

  5. 或者,在“描述”字段中,输入 fork 的描述。

  6. 或者,选择仅复制 DEFAULT 分支

    对于许多 fork 场景(例如,为开源项目做贡献),您只需要复制默认分支。如果您不选择此选项,所有分支都将复制到新的 fork 中。

  7. 点击创建 fork

注意

如果您想从上游存储库复制其他分支,可以在分支页面进行操作。有关更多信息,请参阅“在存储库中创建和删除分支”。

要了解有关 GitHub CLI 的更多信息,请参阅“关于 GitHub CLI”。

要创建存储库的 fork,请使用gh repo fork子命令。

gh repo fork REPOSITORY

要在组织中创建 fork,请使用--org标志。

gh repo fork REPOSITORY --org "octo-org"

您可以在 GitHub.com 或 GitHub Desktop 上 fork 存储库。有关在 GitHub.com 上 fork 的信息,请参阅本文的网页浏览器版本

在 GitHub Desktop 中,如果您尝试克隆您没有写入权限的存储库,则会自动为您创建 fork。

  1. 文件菜单中,点击克隆存储库

    Screenshot of the menu bar on a Mac. The "File" dropdown menu is expanded, and the "Clone Repository" option is highlighted with an orange outline.

    Screenshot of the "GitHub Desktop" menu bar on Windows. The "File" dropdown menu is expanded, and the "Clone Repository" option is highlighted with an orange outline.

  2. 点击与您要克隆的存储库位置相对应的选项卡。您也可以点击URL手动输入存储库位置。

    Screenshot of the "Clone a repository" window. At the top of the window, tabs labeled "GitHub.com", "GitHub Enterprise" and "URL" are highlighted with an orange outline.

  3. 从存储库列表中,点击您要克隆的存储库。

    Screenshot of the "Clone a repository" window. The "github/docs" repository is highlighted with an orange outline.

  4. 要选择要将存储库克隆到的本地目录,在“本地路径”字段旁边,点击选择...并导航到该目录。

    Screenshot of the "Clone a repository" window. A button, labeled "Choose", is highlighted with an orange outline.

  5. 在“克隆存储库”窗口底部,点击克隆

  6. 阅读“您计划如何使用此 fork?”窗口中的信息。

    • 如果您计划将此 fork 用于为原始上游存储库做贡献,请点击为父项目做贡献
    • 如果您计划将此 fork 用于与上游无关的项目,请点击为我自己的目的
  7. 点击继续

克隆您的分叉存储库

现在,您拥有了 Spoon-Knife 存储库的分叉,但您还没有将该存储库中的文件本地存储在您的计算机上。

  1. 在 GitHub 上,导航到您的 Spoon-Knife 存储库的分叉

  2. 在文件列表上方,点击 代码.

    Screenshot of the list of files on the landing page of a repository. The "Code" button is highlighted with a dark orange outline.

  3. 复制存储库的 URL。

    • 要使用 HTTPS 克隆存储库,在“HTTPS”下,点击.

    • 要使用 SSH 密钥(包括您的组织的 SSH 证书颁发机构颁发的证书)克隆存储库,请点击SSH,然后点击.

    • 要使用 GitHub CLI 克隆存储库,请点击GitHub CLI,然后点击.

      Screenshot of the "Code" dropdown menu. To the right of the HTTPS URL for the repository, a copy icon is outlined in dark orange.

  4. 打开终端终端Git Bash

  5. 将当前工作目录更改为您想要克隆目录的位置。

  6. 键入git clone,然后粘贴您之前复制的 URL。它看起来像这样,使用您的 GitHub 用户名代替YOUR-USERNAME

    git clone https://github.com/YOUR-USERNAME/Spoon-Knife
    
  7. Enter。您的本地克隆将被创建。

    $ git clone https://github.com/YOUR-USERNAME/Spoon-Knife
    > Cloning into `Spoon-Knife`...
    > remote: Counting objects: 10, done.
    > remote: Compressing objects: 100% (8/8), done.
    > remote: Total 10 (delta 1), reused 10 (delta 1)
    > Unpacking objects: 100% (10/10), done.
    

要了解有关 GitHub CLI 的更多信息,请参阅“关于 GitHub CLI”。

要创建 fork 的克隆,请使用--clone标志。

gh repo fork REPOSITORY --clone=true
  1. 文件菜单中,点击克隆存储库

    Screenshot of the menu bar on a Mac. The "File" dropdown menu is expanded, and the "Clone Repository" option is highlighted with an orange outline.

    Screenshot of the "GitHub Desktop" menu bar on Windows. The "File" dropdown menu is expanded, and the "Clone Repository" option is highlighted with an orange outline.

  2. 点击与您要克隆的存储库位置相对应的选项卡。您也可以点击URL手动输入存储库位置。

    Screenshot of the "Clone a repository" window. At the top of the window, tabs labeled "GitHub.com", "GitHub Enterprise" and "URL" are highlighted with an orange outline.

  3. 从存储库列表中,点击您要克隆的存储库。

    Screenshot of the "Clone a repository" window. The "github/docs" repository is highlighted with an orange outline.

  4. 要选择要将存储库克隆到的本地目录,在“本地路径”字段旁边,点击选择...并导航到该目录。

    Screenshot of the "Clone a repository" window. A button, labeled "Choose", is highlighted with an orange outline.

  5. 在“克隆存储库”窗口底部,点击克隆

配置 Git 以将您的 fork 与上游存储库同步

当您 fork 一个项目以建议对上游存储库进行更改时,您可以配置 Git 将更改从上游存储库拉取到 fork 的本地克隆中。

  1. 在 GitHub 上,导航到 octocat/Spoon-Knife 存储库。

  2. 在文件列表上方,点击 代码.

    Screenshot of the list of files on the landing page of a repository. The "Code" button is highlighted with a dark orange outline.

  3. 复制存储库的 URL。

    • 要使用 HTTPS 克隆存储库,在“HTTPS”下,点击.

    • 要使用 SSH 密钥(包括您的组织的 SSH 证书颁发机构颁发的证书)克隆存储库,请点击SSH,然后点击.

    • 要使用 GitHub CLI 克隆存储库,请点击GitHub CLI,然后点击.

      Screenshot of the "Code" dropdown menu. To the right of the HTTPS URL for the repository, a copy icon is outlined in dark orange.

  4. 打开终端终端Git Bash

  5. 将目录更改为您克隆的 fork 的位置。

    • 要转到您的主目录,只需键入cd,无需其他文本。
    • 要列出当前目录中的文件和文件夹,请键入ls
    • 要进入列出的目录之一,请键入cd YOUR-LISTED-DIRECTORY
    • 要向上移动一个目录,请键入cd ..
  6. 键入git remote -v并按Enter。您将看到 fork 的当前配置的远程存储库。

    $ git remote -v
    > origin  https://github.com/YOUR-USERNAME/YOUR-FORK.git (fetch)
    > origin  https://github.com/YOUR-USERNAME/YOUR-FORK.git (push)
    
  7. 键入git remote add upstream,然后粘贴您在步骤 3 中复制的 URL 并按Enter。它看起来像这样

    git remote add upstream https://github.com/ORIGINAL-OWNER/Spoon-Knife.git
    
  8. 要验证您为 fork 指定的新上游存储库,请再次键入git remote -v。您应该会看到 fork 的 URL 为origin,上游存储库的 URL 为upstream

    $ git remote -v
    > origin    https://github.com/YOUR-USERNAME/YOUR-FORK.git (fetch)
    > origin    https://github.com/YOUR-USERNAME/YOUR-FORK.git (push)
    > upstream  https://github.com/ORIGINAL-OWNER/ORIGINAL-REPOSITORY.git (fetch)
    > upstream  https://github.com/ORIGINAL-OWNER/ORIGINAL-REPOSITORY.git (push)
    

现在,您可以使用一些 Git 命令来保持 fork 与上游存储库同步。有关更多信息,请参阅“同步 fork”。

要了解有关 GitHub CLI 的更多信息,请参阅“关于 GitHub CLI”。

要为分叉存储库配置远程存储库,请使用--remote标志。

gh repo fork REPOSITORY --remote=true

要指定远程存储库的名称,请使用--remote-name标志。

gh repo fork REPOSITORY --remote-name "main-remote-repo"

编辑 fork

您可以对 fork 进行任何更改,包括

  • 创建分支:分支允许您构建新功能或测试想法,而不会危及您的主要项目。
  • 打开拉取请求:如果您想为上游存储库做贡献,您可以向原始作者发送请求,要求他们通过提交拉取请求将您的 fork 拉取到他们的存储库中。

查找另一个要分叉的存储库

fork 一个存储库以开始为项目做贡献。您可以将任何公共存储库 fork 到您的个人帐户或您有权创建存储库的组织。如果您有权访问私有存储库并且所有者允许 fork,则可以将存储库 fork 到您的个人帐户或您有权创建存储库的 GitHub Team 上的组织。您无法使用 GitHub Free 将私有存储库 fork 到组织。有关 GitHub Team 和 GitHub Free 的更多信息,请参阅“GitHub 的计划”。有关何时可以 fork 存储库的更多信息,请参阅“关于 fork 的权限和可见性”。

您可以浏览探索 GitHub以查找项目并开始为开源存储库做贡献。有关更多信息,请参阅“在 GitHub 上寻找为开源做贡献的方法”。

后续步骤

您现在已经 fork 了一个存储库,练习了克隆您的 fork,并配置了上游存储库。

  • 有关克隆 fork 和从计算机上的分叉存储库同步更改的更多信息,请参阅“设置 Git”。

  • 您还可以创建一个新的存储库,您可以在其中放置所有项目并在 GitHub 上共享代码。为您的项目创建存储库允许您在 GitHub 上存储代码。这为您提供了工作备份,您可以选择与其他开发人员共享。有关更多信息,请参阅“存储库快速入门”。

  • GitHub 上的每个存储库都属于个人或组织。您可以通过在 GitHub 上连接和关注他们来与个人、存储库和组织进行交互。有关更多信息,请参阅“在 GitHub 上寻找灵感”。

  • GitHub 拥有一个很棒的支持社区,您可以在其中寻求帮助并与来自世界各地的人们交流。加入GitHub 社区的对话。