假设我们有一个目录名称叫 bin 的下面的一些二进制文件被不小心提交到了 git 仓库中。这个时候即使我们把 bin 目录加到 .gitignore 文件中,在每次提交代码的时候 git 还是会提示里面的文件被修改了是否要提交。
原因
原因是 bin 目录已经被加入了 git 的 staging area,只要被加入了 staging area。我们可以使用下面的命令来查看有哪些文件在 staging area
git ls-files
git bin 已经被加入了 staging area
所以如果我们能从 staging area 移除这个目录就可以解决问题。我么可以通过 git rm 来实现。
解决方案
但是 git rm 会删除本地目录。那么如何在不删除我们的本地文件的情况下删除这个 bin 目录呢?我们来看看 git rm 的帮助。
git rm 的 --cached 选项可以帮助我们,因为这个命令只从 index 里删除指定的文件。下面是完整的命令,执行完后再查看 git ls-files 就看不到 bin 文件夹了,但是我们的本地 bin 文件夹还在。记得把它加入 .gitignore 文件中防止下次又不小心给提交了。
git rm --cached -r bin/
删除 bin 文件夹
本地的 bin 文件夹还在。
但是 staging area 已经没有 bin 文件夹了。
总结
我们介绍了为什么把某些文件夹加入了 .gitignore 这些文件夹还是被 git 跟踪的原因。解决方案是使用 git rm --cache -r your_folder_name 命令把这些文件夹从 staging area 去掉。