gitignore文件不生效如何解决

在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改根目录中 .gitignore 文件的方法(如果没有这个文件,则需自己手工建立此文件)。这个文件每一行保存了一个匹配的规则例如:

*.sample    	# 忽略所有 .sample 结尾的文件
!lib.sample    # 但 lib.sample 除外
/TODO    		# 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
build/    		# 忽略 build/ 目录下的所有文件
doc/*.txt   	# 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt

把某些目录或文件加入忽略规则,按照上述方法定义后发现并未生效,原因是.gitignore只能忽略那些原来没有被追踪的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。那么解决方法就是先把本地缓存删除(改变成未被追踪状态),然后再提交:

git rm --cached filename
git add .
git commit -m 'update .gitignore'
git push -u origin master

需要特别注意的是:
1、.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。

2、想要.gitignore起作用,必须要在这些文件不在暂存区中才可以,.gitignore文件只是忽略没有被staged(cached)文件, 对于已经被staged文件,加入ignore文件时一定要先从staged移除,才可以忽略。