![061e11b59e8531a376467a6181210954.png](https://img-blog.csdnimg.cn/img_convert/061e11b59e8531a376467a6181210954.png)
有时我们的gitignore没有配置,导致一些大文件被误提交上去~
直接开淦:
1.先找到大文件(如果你已经知道是哪个文件以及该文件的路径,可直接进行第二步)
$ git verify-pack -v .git/objects/pack/pack-*.idx | sort -k 3 -g | tail -5
verify-pack:用于显示已打包的内容
.git/objects/pack/pack-*.idx:列出提交的pack中涉及的文件ID
sort -k 3:按照第三列进行从上到下排序
这行命令是找到排名前5的大文件存在的git记录,从小到大排列。一般最后一个最大的可能就是我们的大文件提交记录。
![050c82f72ae5649202b681a01e805707.png](https://img-blog.csdnimg.cn/img_convert/050c82f72ae5649202b681a01e805707.png)
第一列是表示它的pack的id,拿到它后,这时我们接着下一步,去查看该文件是什么以及文件路径:
2.查找某个id下的大文件内容
$ git rev-list --objects --all | grep ed2ae090b2da43e55e7ef6a436708a01c100b90b
rev-list:用来列出Git仓库中的提交,列出所有提交中涉及的文件名及其ID。
-- objects:列出该提交涉及的所有文件ID。
-- all:所有分支的提交,相当于指定了位于/refs下的所有引用。
此时我们可以看到:
ed2ae090b2da43e55e7ef6a436708a01c100b90b 归档.zip
表示在根目录下有个归档.zip,就是那个大家伙。
3.将该文件从历史记录中移除
git log --pretty=oneline --branches -- 归档.zip
4.重写所有 commit,将该文件从 Git 历史中完全移除
git filter-branch --index-filter 'git rm --cached --ignore-unmatch 归档.zip' -- --all
5.引用完全删除
到这里,历史记录中已经没有该文件了。不过运行 filter-branch 产生的日志还是会对该文件有引用,所以还需要运行以下几条命令,把该文件的引用完全删除:
rm -Rf .git/refs/original //删除git的备份
rm -Rf .git/logs/ // 删除logs
git gc //收集所有松散对象并将它们存入 packfile(垃圾回收)
git prune //删除所有过期的、不可达的且未被打包的松散对象
这是我们再去查看 .git 的大小,小家伙。
(如果还是打的话,继续执行第一步,再次查看哪个大文件,再删除掉)
6.提交
删除之后,需要以强制覆盖的形式提交上去:
$ git push origin xxx --force