我使用“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
答案 0 :(得分:9)
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)以使用分支的新历史覆盖远程仓库。或者你只是推到一个新的空裸仓库。