解决 Git 提交大文件导致 Push 被拒绝的问题

为什么会出现这个情况?

  1. 因为这个代码是二开的,从别的代码仓库下载zip的方式下载的
  2. 并且里面没有.gitignore
  3. 在我们远程仓库没有创建好的情况下我现在本地仓库已经提交了几次代码了,导致提交了jar包上去
  4. 现在要往新建出远程仓库第一次推送的时候出现了这次的问题
  5. 所以本次演示的删除 Git 提交历史中的大文件
  6. 如果是删除未提交的文件直接使用git rm --cached即可

在使用 Git 推送代码到远程仓库(比如 Gitee)时,经常会遇到这样的问题:

shell 复制代码
remote: Find the desired index: <hash>, size: 108.596MB, exceeds quota 100MB
error: failed to push some refs to 'https://gitee.com/your-repo.git'
! refs/heads/master:refs/heads/master [remote rejected] (pre-receive hook declined)

这是因为 Git 历史中存在大文件,超出了远程仓库的限制。本文将详细讲解如何排查并解决此问题。

一、问题分析

  1. 大文件导致 push 被拒绝
    Gitee/GitHub 等平台对单个文件大小有限制(Gitee 默认 100MB)。如果历史提交中存在大文件,就算你在最新提交里删除了,也无法直接 push。
  2. 普通 git rm --cached 不起作用
    仅删除工作区或暂存区的文件,并不会删除 Git 历史里的大文件。

二、排查大文件

在 Windows PowerShell 中,可以使用如下命令找出仓库中最大的文件:

shell 复制代码
git rev-list --objects --all | `
  git cat-file --batch-check='%(objecttype) %(objectname) %(objectsize) %(rest)' | `
  Where-Object { $_ -match "^blob" } | `
  Sort-Object {[int]($_.Split(" ")[2])} -Descending | `
  Select-Object -First 20

输出示例:

注意:这里显示的文件大小是字节数。你可以找到所有超出远程限制的文件。


三、删除大文件

1. 使用 git rm --cached 删除最新提交的文件

从 Git 暂存区(索引)中删除指定文件,但保留工作目录中的文件

shell 复制代码
git rm --cached path/to/largefile
git commit -m "remove large file from latest commit"

这种方法只能删除最新提交中的大文件,历史提交中仍然存在。


2. 删除 Git 历史中的大文件

使用 git filter-branch

⚠️ 警告:这会重写 Git 历史,如果其他人已经克隆了仓库,会导致冲突。确保你是唯一开发者或者团队同意重写历史。

shell 复制代码
# 执行 filter-branch 删除历史中的大文件
git filter-branch --force --index-filter `
"git rm --cached --ignore-unmatch im-admin/ruoyi-admin/target/im-admin.jar" `
--prune-empty --tag-name-filter cat -- --all

2.1 git filter-branch时 有uncommitted changes解决方案

⚠️ 注意:

  • Windows 下需要确保暂存区没有文件被 staged,否则会报错。
  • 删除完成后,需要强制 push:
  • 如果暂存区有文件被 staged 就会出现如下图所示报错
  1. 查看当前仓库的状态
shell 复制代码
 git status
  1. 将暂存区(staging area)中的 .DS_Store 文件撤回到未暂存状态 ,也就是取消 git add.DS_Store 的操作,但不会删除工作目录中的文件。
shell 复制代码
git restore --staged .DS_Store
  1. 最后使用 git filter-branch 对Git 历史中的大文件进行删除
  1. 删除成功后再次推送就能成功推送了
shell 复制代码
git push origin master --force

四、预防措施

  1. 添加 .gitignore 忽略临时文件和 target 目录
git 复制代码
# Maven
**/target/
*.jar

# macOS
.DS_Store
  1. 使用 Git LFS 管理大文件(可选)
    对于必须提交的大文件(>100MB),可以使用 Git LFS 来管理。
shell 复制代码
git lfs install
git lfs track "*.jar"

五、总结

  • Push 被拒绝原因:仓库历史中存在大文件。
  • 排查方法 :使用 git rev-list + git cat-file 查找最大文件。
  • 解决方法
    1. 删除暂存区大文件:git rm --cached
    2. 删除历史大文件:git filter-branchgit filter-repo
  • 预防措施 :使用 .gitignore、Git LFS。

通过以上方法,你就可以清理 Git 仓库中的大文件,顺利推送到远程仓库。

相关推荐
梦未2 小时前
Spring控制反转与依赖注入
java·后端·spring
喜欢流萤吖~2 小时前
Lambda 表达式
java
无限大62 小时前
验证码对抗史
后端
ZouZou老师2 小时前
C++设计模式之适配器模式:以家具生产为例
java·设计模式·适配器模式
用户2190326527352 小时前
Java后端必须的Docker 部署 Redis 集群完整指南
linux·后端
曼巴UE52 小时前
UE5 C++ 动态多播
java·开发语言
VX:Fegn08952 小时前
计算机毕业设计|基于springboot + vue音乐管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·课程设计
程序员鱼皮3 小时前
刚刚,IDEA 免费版发布!终于不用破解了
java·程序员·jetbrains