本技能指导用户使用 git filter-repo 工具从 Git 仓库的完整历史记录中彻底删除指定文件。
询问用户是否需要备份仓库(强烈建议)
必须用户确认后,继续执行后续步骤。
在执行任何操作前,先备份仓库:
# 方式1:复制整个仓库目录
cp -r your-repo your-repo-backup
# 方式2:创建裸仓库备份
git clone --bare your-repo your-repo-backup.git
根据操作系统选择安装方式:
macOS:
brew install git-filter-repo
Ubuntu / Debian:
pip install git-filter-repo
Windows:
pip install git-filter-repo
进入仓库目录后检查:
git status
git remote -v
如果没有远程仓库,先添加:
git remote add origin git@github.com:用户名/仓库名.git
假设要删除的文件是 secrets.txt:
git filter-repo --path secrets.txt --invert-paths
这一步的作用:
删除多个文件:
git filter-repo --path file1.txt --path file2.txt --path secrets/ --invert-paths
删除整个目录:
git filter-repo --path 目录名/ --invert-paths
查看历史中是否还有这个文件:
git log --all -- 文件名
如果没有输出,说明已经删干净了。
因为历史被重写了,必须强制推送:
# 推送所有分支
git push origin --force --all
# 推送所有标签
git push origin --force --tags
如果删除的是敏感信息(密钥、token、密码、私钥),除了删除历史,还要:
重要提醒: 历史删掉了,不代表别人之前没复制走。一旦敏感信息被提交到公开仓库,就应当视为已泄露。
因为 commit 历史变了,其他人本地仓库会和远程不一致。需要通知他们:
```bash
git fetch origin
git reset --hard origin/main # 会丢失本地未推送的更改,谨慎使用
```
确保你在 Git 仓库根目录下执行命令。
先安装 git-filter-repo,参考上面的安装步骤。
需要执行垃圾回收:
git gc --aggressive --prune=now
如果文件只在最近一次 commit 中,不需要用 filter-repo,用:
git rm --cached 文件名
git commit --amend
最核心的命令:
# 删除文件
git filter-repo --path 文件名 --invert-paths
# 如果没有远程,先添加
git remote add origin <repo-url>
# 强制推送
git push origin --force --all
git push origin --force --tags
共 1 个版本