我使用“git Replace”来替换分支(没有共同祖先)22b2b25 来替换 master 中的提交。我希望这种改变是永久性的。我对以前的历史不感兴趣。在下面的输出中,前 5 个提交来自原始 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
git replace单独是不够的:替换一个提交是不够的。
下一个提交现在必须引用替换的提交作为父级。
正如《从 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),以便使用分支的新历史记录覆盖远程存储库。或者你只是推送到一个新的空的裸仓库。
更新(灵感来自Stephen的评论)
正如我在 2019 年 10 月的《可能破坏/重写历史的 Git 命令"、git filter-branch 或 BFG 已过时。
git filter-repo使用更方便,效率更高。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)