git彻底删除大文件

2019-05-17  本文已影响0人  鱼豆腐爱好者协会会长

以下操作很危险,操作前请确定你清楚你在执行什么操作,请做好必要的备份

👉拉取分支代码

git clone 你的远程分支地址

git checkout master

👉删除要干掉的大文件

git rm --cached -rf res/

rm -rf res/

👉提交修改

git commit -m '删除无用文件'

👉清理空间,并打包成pack

git gc

👉查看size-pack的大小(实际并没有减少,clone时还会出现)

git count-objects -v

👉查看.git/objects/pack/文件夹中最新的idx文件

pack-8ec65b4812ef28bda4ae012f9ebae1bc793f7ad6.idx

👉找出最大的文件(按第3列进行排序,取最后10个大文件)

git verify-pack -v .git/objects/pack/pack-8ec65b4812ef28bda4ae012f9ebae1bc793f7ad6.idx | sort -k 3 -n | tail -10

👉确定这个文件是什么文件(不要误删了其他文件)

git rev-list --objects --all | grep 1d308d156e

👉确定哪次提交引入的(找最底下的提交就行了)

git log --oneline --branches -- res/JPG_5667.jpg

👉重写从引入提交开始往后的所有提交

git filter-branch --index-filter 'git rm --ignore-unmatch --cached res/JPG_5667.jpg' -- 05567b1^..

👉我们要删除的是一批大文件

git log --oneline --branches -- res/*

👉当之前的重写不对时,-f 强制覆盖之前的重写

git filter-branch -f --index-filter 'git rm --ignore-unmatch --cached res/*' -- f9fbf6c^..

👉重写完成,删除引用信息

rm -Rf .git/refs/original

git reflog expire --expire=now --all

👉重新打包

git gc --aggressive --prune=now

👉查看本地的size-pack是否减小了(实践证明,本地是没有减小的)

git count-objects -v

👉最后勇敢的把本地的危险操作推送到远程分支(最好自己本地做个备份吧,到时回不了头就不好了)

git push origin master --force

上一步你可能遇到master是个保护分支,那么取消保护吧(操作完要保护回来哦)

👉删掉本地代码,重写clone远程分支

👉再次查看size-pack的大小(其实你在clone的时候已经感受到大文件已经没有了)

git count-objects -v

上一篇下一篇

猜你喜欢

热点阅读