在git使用时不小心commit了大文件,如何删除commit中的大文件记录

经常会因为在git使用时不小心commit了大文件,如何删除commit中的大文件记录

问题背景:由于许多人在使用git命令的时候,习惯于使用 git add . 添加所有更改的命令,这个习惯会导致在进行git 进行push的时候,由于无意间提交commit缓存的大文件,阻止正常的push 从而很难解决,本文为了解决这问题,有以下小经验(文章广泛参考了其他帖子)

如果你也因为在github push文件的时候遇到“this exceeds GitHub’s file size limit of 100.00 MB”而苦恼,请使用本文中的方法解决问题:

  1. 首先,我们需要找到是哪些文件在作祟:
    使用下面的命令,帮你找出top10 在git提交中的巨大文件,并且显示其相关信息(位置信息最为重要)

    git rev-list --all | xargs -rL1 git ls-tree -r --long | sort -uk3 | sort -rnk4 |        head -10
    
  2. 找到文件之后,请用下面的命令进行移除制定文件目录下的大文件,并且重写当前分支内容(请替换下面命令中的{xxx}作为你上面显示的,并且你想要移除的某一个大文件):

    git filter-branch --force --index-filter 'git rm -r --cached --ignore-unmatch {xxx}' --prune-empty --tag-name-filter cat -- --all
    
  3. 注意,如果你在运行上面指令的时候,出现了“Cannot rewrite branches: You have unstaged changes”这样的bug,请按照下面的方法来解决:

    git stash
    
  4. 下面,请继续执行步骤2中的命令,注意请连括号一起替换了,这里不需要任何引号或者括号,直接输入路径就好,按照2所示,把所有大文件都移除掉之后,应该就可以重新进行push了。

respect!!!

你可能感兴趣的:(vscode,stash,git,git,push,git,commit)