第一步,找出大文件或误添加的文件

git rev-list --objects --all | grep "$(git verify-pack -v .git/objects/pack/*.idx | sort -k 3 -n | tail -5 | awk '{print $1}')"

第二步,从仓库中删除文件或文件夹

删文件,将 bigfile 换成上面找出的文件名

git filter-branch --force --index-filter \
  'git rm --cached --ignore-unmatch "bigfile"' \
  --prune-empty -- --all

删文件夹,将 wrongdir 换成上面找出的文件夹

git filter-branch --force --index-filter \
  'git rm -r --cached --ignore-unmatch "wrongdir"' \
  --prune-empty -- --all

第三步,删除缓存的对象

这一步可以暂时跳过,等到确认完全不会出现问题之后再执行。(这些缓存对象给你提供了撤销操作的一次机会)。

git for-each-ref --format='delete %(refname)' refs/original | git update-ref --stdin
git reflog expire --expire=now --all
git gc --prune=now

第四步,强制更新远程仓库

(这一步执行了,就真没救了。请确认已备份。)

git push --force --verbose --dry-run
git push --force

 

相关文章:

  • 2021-06-25
  • 2022-02-20
  • 2021-10-11
  • 2021-12-22
  • 2021-08-05
  • 2022-01-22
  • 2021-08-29
  • 2021-10-31
猜你喜欢
  • 2022-12-23
  • 2019-11-01
  • 2022-01-05
  • 2021-09-08
  • 2022-02-21
  • 2021-07-29
相关资源
相似解决方案