1. 问题描述
最近使用Gitee一直在独立开发某个项目,某次因为某个测试文件比较大,超过了100MB,gitee无法接受,上传失败。但是当时我没有发现上传失败,就没有处理,等到今天发现的时候,已经提交过好多次代码了,都是提交到了缓存里,并没有提交到远程分支下。
报错如下图所示:
2. 尝试解决
google了好多方法,常见的解决办法如下:
$ git filter-branch --force --index-filter "git rm --cached --ignore-unmatch SampleData/nx/13160600016953_A.prt_Result 20230607.brep" --prune-empty --tag-name-filter cat -- --all
$ git filter-branch --tree-filter 'rm -f SampleData/nx/13160600016953_A.prt_Result 20230607.brep' --tag-name-filter cat -- --all
$ git rm --cached 'SampleData/nx/13160600016953_A.prt_Result 20230607.brep'
$ git filter-branch --tree-filter 'rm -f SampleData/nx/13160600016953_A.prt_Result 20230607.brep' HEAD
$ git filter-branch --force --index-filter 'git rm --cached --ignore-unmatch SampleData/nx/13160600016953_A.prt_Result 20230607.brep' --$ prune-empty --tag-name-filter cat -- --all
$ git filter-branch --force --index-filter 'git rm -rf --cached --ignore-unmatch SampleData/nx/13160600016953_A.prt_Result 20230607.brep' --prune-empty --tag-name-filter cat -- --all
但是都不能解决问题,尝试上述代码后push代码,显示 Ref ‘refs/heads/master’ is unchanged,push仍然失败。
3. 最终解决方案
1 借助git reset --soft 回到提交大文件之前的状态
$ git reset --soft 99a8a18ead63802df7cc0163dfa8afe4db0fb059
git reset --soft 命令用于将 Git 存储库中的当前分支的 HEAD 指针和索引(Index)重置为指定提交,但不更改工作目录中的文件。这意味着此命令将取消之前的提交,并将其撤回到工作区,以便修改之前提交的内容并重新提交。
2 git restore --staged 取消暂存
$ git restore --staged .
将已暂存(staged)的指定文件的更改还原到未暂存(unstaged)状态。要注意的是,该命令仅针对已经通过 git add 命令添加到暂存区的文件。
3 修改.gitignore,使大文件不上传
修改.gitignore后,提交.gitignore,从而使上传的数据不包括测试大文件
$ git add .gitignore
$ git commit -m "add .gitignore"
$ git push
4 提交剩余的修改
把后面所有的修改合为一个,统一一次性全部提交
$ git add .
$ git commit -m "XXX"
$ git push
成功解决此问题,效果如下