以下操作很危险,操作前请确定你清楚你在执行什么操作,请做好必要的备份
👉拉取分支代码
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