Git 巨大失误案例记录 (2026-05-01)

Git 巨大失误案例记录 (2026-05-01)

事故概述

清理 Git 仓库大文件时,使用git filter-branch` 操作失误。


事故经过

第1步:发现问题

  • 远程仓库 大小超过 1024MB
  • 本地仓库大小:127.22 MiB
  • 最大文件:uite_Setup.exe (54.41 MB)

第2步:尝试清理

bash 复制代码
git verify-pack -v .git\objects\pack\*.idx
git rev-list --objects --all | sort -k 3 -n -r | head -20

第3步:使用 filter-branch 重写历史

bash 复制代码
git filter-branch --force --index-filter "git rm -r --cached --ignore-unmatch te_Setup.exe Out/ setup/ Plugins/" --prune-empty --tag-name-filter cat -- --all

第4步:删除备份引用(错误!)

bash 复制代码
git update-ref -d refs/original/refs/heads/master
git update-ref -d refs/original/refs/remotes/origin/master

第5步:执行 GC

bash 复制代码
git reflog expire --expire=now --all
git gc --prune=now --aggressive

第6步:尝试推送(失败)

bash 复制代码
git push -f origin master

失败原因:远程仓库还有旧的大对象未清理,超过 Gitee 1024MB 限制


清理前后对比

项目 清理前 清理后
Git 仓库大小 127.22 MiB 1.21 MiB
Git 对象数 974 498
最大文件 ite_Setup.exe (54.41 MB) g.doc (0.29 MB)
大文件已从历史中删除 setup/ (22个文件 已删除
Plugins/ (48个文件 已删除
Out/ (374个文件 已删除

⚠️ 教训总结

✅ 正确做法

  1. 先备份!

    bash 复制代码
    # 备份整个 .git 目录
    xcopy .git .git-backup /E /I /H /Y
  2. 使用 BFG Repo-Cleaner!

    bash 复制代码
    # 下载 BFG(比 filter-branch 更安全、更快
    java -jar bfg.jar --delete-files uite_Setup.exe
  3. 不要删除备份引用!

    • `refs/original/ 是 filter-branch 的安全网,后悔还可以恢复
  4. 远程仓库先 GC!

    • Gitee 上执行 GC 清理历史对象
    • 再强制推送

❌ 错误做法

  1. 不要直接删除 refs/original/
  2. 不要没有备份就操作
  3. 不要忽略远程仓库没清理就推送
  4. 不要用 git rm 不带 --cached(虽然这次带了,但用户担心)

教训文档

  • v2-remaining-work-plan.md

  • code-review-report-plan.md

相关推荐
Promise微笑5 小时前
深度解码GEO优化:内容交叉验证的实战策略与AI信任构建
大数据·人工智能·知识图谱
jinanwuhuaguo5 小时前
OpenClaw算力共生体——从Token奴隶到异构计算联邦的经济基础重构(第二十五篇)
大数据·人工智能·重构·安全架构·openclaw
Aaron15885 小时前
RFSOC+VU13P+GPU 在6G互联网中的技术应用
大数据·人工智能·算法·fpga开发·硬件工程·信息与通信·信号处理
Elasticsearch5 小时前
在不丢弃数据的情况下修复 Elastic Streams 处理失败问题
elasticsearch
动恰客流管家6 小时前
动恰3DV3丨2026年实体商业数字化转型:客流数据是第一生产力——全场景智慧客流解决方案
大数据·人工智能·3d·性能优化
逸Y 仙X6 小时前
文章十七:ElasticSearch get\search查询相关参数
java·大数据·elasticsearch·搜索引擎·全文检索
Elasticsearch6 小时前
构建一个控制平面来治理电子商务搜索
elasticsearch
CS创新实验室6 小时前
CS实验室行业报告:游戏行业就业分析报告
大数据·游戏
donecoding6 小时前
Git Worktree:一个仓库同时在多个分支工作,告别 stash 地狱
git