我们使用git的时候总会因为手滑等各种原因将我们不想提交的文件提交到git中,可能是某个写着密码的文件,也可能是打包好的二进制或镜像等等,总而言之这些不必要的文件提交上去以后要么就是遗留了安全风险,要么就是平白无故占据着大量我们的仓库空间,而因为git记录历史版本的特点,直接将这些文件删除再提交并不能真正从git中删除他们,这样操作只是提交了一个【删除该文件】的操作而已,文件本身其实还是存在git中的,翻翻历史版本就能再把他们找出来 ?
总而言之打开你想要操作的项目目录,右键-Git Bash Here,然后输入下面的内容
git filter-branch --force --index-filter 'git \
rm --cached --ignore-unmatch 你要删除的文件名' \
--prune-empty --tag-name-filter cat -- --all
参数 | 意思 |
---|
filter-branch | 让git重写每一个分支 | –force | 假如遇到冲突也让git强制执行 | –index-filter | 指定重写的时候应该执行什么命令,要执行的命令紧跟在它的后面,在这里就是git rm --cached --ignore-unmatch 你要删除的文件名 让git删除掉缓存的文件,如果有匹配的话 | –prune-empty | 告诉git,如果因为重写导致某些commit变成了空(比如修改的文件全部被删除),那么忽略掉这个commit | –tag-name-filter | 表示对每一个tag如何重命名,重命名的命令紧跟在后面,用cat就表示保持tag名不变 | – | 分隔符 | –all | 对所有的文件都考虑在内 |
然后敲回车就可以辣 但是删除的过程会很漫长,他本质上是去遍历一遍你项目的git树,从每一个节点中去搜索你输入的文件名,找到有就删掉,总而言之是一个很耗时间的工作,而且你项目git树越长消耗的时间越多,需要有一定的耐心 执行完成后你会发现,本地项目文件夹下的.git文件夹的大小并没有变化,这是因为该命令实际上影响的是仓库里的数据,而非你本地的数据,你可以通过拉取等方式与仓库进行同步,不过我推荐你使用更为直接的方式——把本地的项目文件夹直接删掉,重新从仓库克隆一次项目到本地,我感觉这是最简单的
参考文档
Git 永久删除文件
|