Skip to main content

此版本的 GitHub Enterprise Server 将于以下日期停止服务 2024-08-29. 即使针对重大安全问题,也不会发布补丁。 为了获得更好的性能、更高的安全性和新功能,请升级到最新版本的 GitHub Enterprise。 如需升级帮助,请联系 GitHub Enterprise 支持

将子文件夹拆分成新仓库

您可以将 Git 仓库内的文件夹变为全新的仓库。

Platform navigation

注意:需要 Git 版本 2.22.0 或更高版本才能按照这些说明进行操作,否则 git filter-repo 将不起作用。****

如果您创建仓库的新克隆副本,则将文件夹拆分为单独的仓库时不会丢失任何 Git 历史记录或更改。 但是,请注意,新存储库不会具有原始存储库的分支和标记。

  1. 打开终端终端Git Bash

  2. 将当前工作目录更改为您要创建新仓库的位置。

  3. 克隆包含该子文件夹的仓库。

    git clone https://HOSTNAME/USERNAME/REPOSITORY-NAME
    
  4. 将当前工作目录更改为您克隆的仓库。

    cd REPOSITORY-NAME
    
  5. 若要从存储库中的其余文件中筛选出子文件夹,请安装 git-filter-repo,然后使用以下参数运行 git filter-repo

    • FOLDER-NAME:项目中要在其中创建单独存储库的文件夹。

    提示:Windows 用户应使用 / 来分隔文件夹。

    $ git filter-repo --path FOLDER-NAME/
    # Filter the specified branch in your directory and remove empty commits
    

    现在,该仓库应仅包含您的子文件夹中的文件。

    如果希望将某个特定子文件夹用作新存储库的新根文件夹,可使用以下命令:

    $ git filter-repo --subdirectory-filter FOLDER-NAME
    # Filter the specific branch by using a single sub-directory as the root for the new repository
    
  6. 在 GitHub Enterprise Server 上新建存储库

  7. 在 你的 GitHub Enterprise Server 实例 的快速设置页面上的新存储库顶部,单击 以复制远程存储库 URL。

    存储库中“快速设置”标头的屏幕截图。 在远程 URL旁边,两个重叠正方形的图以橙色轮廓突出显示。

    提示:有关 HTTPS 和 SSH URL 之间区别的信息,请参阅“关于远程仓库”。

  8. 使用为存储库复制的 URL 添加新的远程名称。 例如,originupstream 是两个常见的选项。

    git remote add origin https://HOSTNAME/USERNAME/REPOSITORY-NAME.git
    
  9. 用新的存储库名称验证是否已添加远程 URL。

    $ git remote -v
    # Verify new remote URL
    > origin  https://HOSTNAME/USERNAME/NEW-REPOSITORY-NAME.git (fetch)
    > origin  https://HOSTNAME/USERNAME/NEW-REPOSITORY-NAME.git (push)
    
  10. 将您的更改推送到 GitHub Enterprise Server 上的新仓库。

    git push -u origin BRANCH-NAME