【Git删除大文件失败,提示WARNING: Ref ‘refs/heads/master‘ is unchanged的解决思路】

1. 问题描述

最近使用Gitee一直在独立开发某个项目,某次因为某个测试文件比较大,超过了100MB,gitee无法接受,上传失败。但是当时我没有发现上传失败,就没有处理,等到今天发现的时候,已经提交过好多次代码了,都是提交到了缓存里,并没有提交到远程分支下。
报错如下图所示:
【Git删除大文件失败,提示WARNING: Ref ‘refs/heads/master‘ is unchanged的解决思路】_第1张图片

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

成功解决此问题,效果如下
【Git删除大文件失败,提示WARNING: Ref ‘refs/heads/master‘ is unchanged的解决思路】_第2张图片

你可能感兴趣的:(git,git,gitee,github)