如何将git-replace推送到远程仓库?

时间:2015-06-14 11:45:48

标签: git

我使用“git replace”替换了一个分支(没有共同的祖先)22b2b25来代替master中的提交。我希望这种改变是永久性的。我对以前的历史不感兴趣。在下面的输出中,前五个提交来自原始主分支,而底部2来自不同的分支。

当我将其推送到新的存储库时,git-replace丢失了,旧历史再次出现。有没有办法让这种变化永久化?

分支大师在原始仓库中看起来如下所示。我希望在远程仓库和后续克隆中看到这一点。

[mike@localhost canal_site]$ git log --oneline --decorate
cdf0ae3 (HEAD, origin/master, master) MM: sqlencode course name for ad-hoc courses
2b57df5 MM: fixes for changes so far
7916eaf MM: ad hoc - more refactoring
1e00d22 MM: reformatted code
e36cee1 factored out equal ops
22b2b25 (origin/prod20140313, prod20140313) initial load from production 9-June-2015
08379cd initial inclusion of production files from 9-June-2015

1 个答案:

答案 0 :(得分:9)

仅仅{p> git replace是不够的:替换一个提交是不够的。

现在,下一次提交必须将替换的提交引用为父级。

如“Removing a whole bunch of commits from git”中所述:

  

通过git clone备份您的仓库   在您不喜欢的提交后找出您喜欢的第一个提交,并记住其直接祖先的哈希值(在下面的bbb中)。
  然后在你不喜欢的提交之前找到你喜欢的第一个提交(在下面的aaa中):

git replace bbb aaa
  

查看您的存储库(使用git log)并检查一切是否符合预期更改后的情况。
  但replace命令只是将一些元信息添加到.git/refs/replace中,git命令相应地解释   为了使这些更改成为永久更改,您可以使用git filter-branch

git filter-branch -- --all

然后您需要强制推送(git push --force)以使用分支的新历史覆盖远程仓库。或者你只是推到一个新的空裸仓库。