Skip to main content

此版本的 GitHub Enterprise 已停止服务 2022-06-03. 即使针对重大安全问题,也不会发布补丁。 要获得更好的性能、改进的安全性和新功能,请升级到 GitHub Enterprise 的最新版本。 如需升级方面的帮助,请联系 GitHub Enterprise 支持

镜像仓库

要维护存储库的镜像而不对其进行复刻,可以运行特殊的克隆命令,然后镜像推送到新存储库。

在将原始存储库推送到存储库的新副本或镜像之前,必须在 您的 GitHub Enterprise Server 实例 上创建新的存储库。 在以下示例中,exampleuser/new-repositoryexampleuser/mirrored 是镜像。

镜像仓库

  1. 打开 Terminal(终端)Terminal(终端)Git Bash
  2. 创建仓库的裸克隆。
    $ git clone --bare https://主机名/exampleuser/old-repository.git
  3. 镜像推送至新仓库。
    $ cd old-repository.git
    $ git push --mirror https://主机名/exampleuser/new-repository.git
  4. � 除您之前创建的临时本地仓库。
    $ cd ..
    $ rm -rf old-repository.git

镜像包含 Git Large File Storage 对象的仓库。

  1. 打开 Terminal(终端)Terminal(终端)Git Bash
  2. 创建仓库的裸克隆。 将示例用户名替换为拥有仓库的个人或组织的名称,并将示例仓库名称替换为要复制的仓库的名称。
    $ git clone --bare https://主机名/exampleuser/old-repository.git
  3. 导航到刚克隆的仓库。
    $ cd old-repository.git
  4. 拉取仓库的 Git Large File Storage 对象。
    $ git lfs fetch --all
  5. 镜像推送至新仓库。
    $ git push --mirror https://主机名/exampleuser/new-repository.git
  6. 将仓库的 Git Large File Storage 对象推送至镜像。
    $ git lfs push --all https://github.com/exampleuser/new-repository.git
  7. � 除您之前创建的临时本地仓库。
    $ cd ..
    $ rm -rf old-repository.git

镜像其他位置的仓库

如果要镜像其他位置的仓库,包括从原始位置获取更新,可以克隆镜像并定期推送更改。

  1. 打开 Terminal(终端)Terminal(终端)Git Bash

  2. 创建仓库的裸镜像克隆。

    $ git clone --mirror https://主机名/exampleuser/repository-to-mirror.git
  3. 设置到镜像的推送位置。

    $ cd repository-to-mirror
      $ git remote set-url --push origin https://主机名/exampleuser/mirrored

    与裸克隆一� �,镜像的克隆包括所有远程分支和� �记,但每次获取时都会覆盖所有本地引用,� 此它始终与原始仓库相同。 设置推送 URL 可简化至镜像的推送。

  4. 如需更新镜像,请获取更新和推送。

    $ git fetch -p origin
    $ git push --mirror