维护 git 存储库的克隆

Maintaining a clone of a git repository

我想在(自托管)bitbucket 服务器中克隆 github 存储库,并时常从 github 存储库中提取最新更改。在我们的克隆中,我们将做一些实验性的东西,这些东西永远不会离开我们的存储库。

举例说明;对于 fossil,我会确保我们的存储库和他们的存储库具有相同的项目 ID,我会这样做:

$ cd ~/checkout/prjdir
$ fossil pull https://their.org/prj/foo --once

这将获取所有最新签到、分支、标签等。然后将其推送到我们组织的服务器:

$ fossil push

永远不会有任何冲突;我们的更改将在实验分支上进行,因此从上游更新时不需要任何合并。

我试图复制化石工作流程和 copy/pasted 一些看起来相关的东西,并为初始克隆提出了这个:

$ git clone https://github.com/foo/bar.git
$ cd bar
$ git remote set-url origin https://ourbitbucket.org/foo/bar.git
$ git push -u origin master

然而,这似乎并没有带来标签(标签对我们很重要)。

使用 git(github 作为上游,我们的 bitbucket 服务器作为我们自己的 tags/branches):

  1. 如何制作存储库的完整克隆(包括所有 分支和标签)?
  2. 一旦我有了一个克隆的存储库,我该如何 从上游拉取所有最新的更改(包括分支、标签) (在 github 上)并将它们推送到我们的服务器 (bitbucket)?

不要更改存储库的 URL。只需创建两个遥控器,upstreamorigin

默认情况下不推送标签。使用 --tags 来推动它们。

$ git clone https://github.com/foo/bar.git
$ cd bar
$ git remote rename origin upstream
$ git remote add origin https://ourbitbucket.org/foo/bar.git
$ git push -u --tags origin master

每当你想与上游同步时,做

$ git checkout master
$ git pull upstream master

甚至

$ git reset --hard upstream/master

并重新设置您的分支(或将 master 合并到其中)以将他们的更改合并到您的工作中:

$ git checkout my-branch
$ git rebase master

$ git checkout my-branch
$ git merge master