GIT历史存在大文件的解决办法

问题触发

在今天迁移项目的时候,触发了一个报错无法推送 refs 到远端。您可以试着运行"拉取"功能,整合您的更改。看了看报错日志发现问题在这里:remote: Find the desired index: b4fc9cd2860327f09ae017bb50ecdadc9fc7d76a, size: 134.975MB, exceeds quota 100MB

可以看出是因为历史大文件导致的无法成功推送。

问题解决

1.找到这个大文件是什么

首先我们使用如下命令去找到这个大文件是什么:

cmd 复制代码
git rev-list --objects --all | git cat-file --batch-check='%(objecttype) %(objectname) %(objectsize) %(rest)' | awk '/^blob/ {if ($3 > 100000000) print substr($0,53)}'

一般会返回如下的值

415 XXX.jar

在这个数据里面 415代表的是大小 415M, 后面就是代表着他的文件名称。

2.在历史中删除该文件

现在考虑使用git filter-repo工具

2.1.安装 filter-repo

安装git-filter-repo(如果尚未安装):

bash 复制代码
pip install git-filter-repo

2.2 根据大小删除文件

这个是根据大小来删除文件的办法 可以删除 100M以上的文件

bash 复制代码
git filter-repo --strip-blobs-bigger-than 100M

3.清理本地仓库

这一步是为了防止有缓存等影响之后的数据:

ini 复制代码
git reflog expire --expire=now --all
git gc --prune=now --aggressive
git count-objects -vH  # 检查仓库大小

4.强制推送清理后的历史

css 复制代码
git push origin master --force

结束

补充说明

如果上述没有办法解决, 也可以试试 备选方案:手动创建新仓库。

相关推荐
极速蜗牛24 分钟前
告别部署焦虑!PinMe:前端开发者的极简部署神器
前端·javascript
乘风!1 小时前
NSSM启动tomcat部署Java程序
java·服务器·后端·tomcat
代码无疆1 小时前
学点java字节码更易于理解一些特殊的java语法效果
java·后端
uhakadotcom1 小时前
Python Protobuf 全面教程:常用 API 串联与实战指南
前端·面试·github
乐之者v1 小时前
使用Git 要注意的
git
by__csdn1 小时前
微前端架构:从理论到实践的全面解析
前端·javascript·vue.js·架构·typescript·vue·ecmascript
漫长的~以后1 小时前
Edge TPU LiteRT V2拆解:1GB内存设备也能流畅跑AI的底层逻辑
前端·人工智能·edge
小福气_2 小时前
自定义组件 vue3+elementPlus
前端·javascript·vue.js
星浩AI2 小时前
AI 并不懂文字,它只认向量:一文搞懂 Embedding
后端
程序员博博2 小时前
这才是vibe coding正确的打开方式 - 手把手教你开发一个MCP服务
javascript·人工智能·后端