我目前有一个本地Git存储库,我将其推送到Github存储库 .
本地存储库有~10次提交,Github存储库是此的同步副本 .
我想要做的是从本地Git存储库中删除所有版本历史记录,因此存储库的当前内容显示为唯一的提交(因此存储库中的旧版本文件不会存储) .
然后,我想将这些更改推送到Github .
我已经调查了Git rebase,但这似乎更适合删除特定版本 . 另一个可能的解决方案是删除本地仓库,并创建一个新的仓库 - 虽然这可能会创造很多工作!
ETA:有一些未跟踪的特定目录/文件 - 如果可能的话,我想保持这些文件的跟踪 .
12 回答
为此使用Shallow Clone命令git clone --depth 1 URL - 它将只克隆存储库的当前HEAD
这是蛮力的方法 . 它还会删除存储库的配置 .
Note :如果存储库有子模块,这不起作用!如果您正在使用子模块,则应使用例如interactive rebase
第1步:删除所有历史记录( Make sure you have backup, this cannot be reverted )
第2步:仅使用当前内容重建Git仓库
第3步:推送到GitHub .
对我有用的唯一解决方案(并保持子模块正常工作)是
当我有子模块时,删除
.git/
总是会导致很大的问题 . 使用git rebase --root
会以某种方式给我带来冲突(并且因为我有很多历史记录需要很长时间) .这是我最喜欢的方法:
这将创建一个新分支,其中一个提交会在HEAD中添加所有内容 . 它不会改变任何其他东西,所以它是完全安全的 .
另一个选项,如果你有很多提交,可能会成为很多工作,是一个交互式的rebase(假设你的git版本> = 1.7.12):
git rebase --root -i
在编辑器中显示提交列表时:
将"pick"更改为"reword"进行第一次提交
将"pick"更改为"fixup"每隔一次提交
保存并关闭 . Git将开始变基础 .
最后,您将拥有一个新的根提交,它是所有提交后的提交的组合 .
优点是您不必删除您的存储库,如果您有第二个想法,您总是有一个后备 .
如果您确实想要查看历史记录,请将master重置为此提交并删除所有其他分支 .
larsmans提出的方法的变体:
保存未记录文件列表:
保存你的git配置:
然后执行larsmans的第一步:
恢复配置:
取消您未跟踪的文件:
然后提交:
最后推送到您的存储库:
你可以使用浅clones(git> 1.9):
进一步阅读:http://blogs.atlassian.com/2014/05/handle-big-repositories-git/
下面的方法是完全可重现的,因此如果双方都一致,则无需再次运行clone,只需在另一侧运行脚本 .
如果您想要清理它,请尝试以下脚本:
http://sam.nipl.net/b/git-gc-all-ferocious
我为存储库中的每个分支编写了一个“杀死历史记录”的脚本:
http://sam.nipl.net/b/git-kill-history
另见:http://sam.nipl.net/b/confirm
这将删除所有本地分支和标记,使用当前结帐的状态进行单个无历史提交,无论当前分支是什么,并保留有关您的repo的其他所有信息 . 然后,您可以根据需要强制推送到遥控器 .
一个更概念性的答案:
如果没有标签/分支/ refs指向它们,git会自动垃圾收集旧提交 . 因此,您只需删除所有标记/分支并创建与任何分支关联的新孤立提交 - 按照惯例,您可以让分支
master
指向该提交 .除非他们使用低级git命令进行挖掘,否则任何人都不会再看到旧的,无法访问的提交 . 如果这对你来说已经足够了,我会停在那里让自动GC随时随地完成它的工作 . 如果你想立即摆脱它们,可以使用
git gc
(可能使用--aggressive --prune=all
) . 对于远程git存储库,除非您具有对其文件系统的shell访问权限,否则您无法强制执行此操作 .More info here.
Git tutoturial here提供了有关如何清除存储库的帮助:
我通过从项目中删除
.git
文件夹并通过IntelliJ重新集成版本控制来解决类似的问题 . 注意:隐藏了.git
文件夹 . 您可以使用ls -a
在终端中查看它,然后使用rm -rf .git
将其删除 .