小强哥博客

小强哥,小强哥博客,技术大咖

Git配置.gitignore规则

在Git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改 .gitignore 文件的方法,这个文件每一行保存了一个匹配的规则,例如:

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

等等,还有其他更多的配置。

这样配置完成以后,符合该规则的文件是不会被加入到版本库中的。

如下是我自己的在eclipse+maven下的配置,如下,

/target/
/logs/
/bin/
*.classpath
*.project
*.gitignore
*.settings/

按照上面的配置有可能在某些情况下不起作用,原因是.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的,那么解决方法就是先把本地缓存删除(改变成未track状态),然后再提交,如下git命令,

git rm -r --cached .
git add .
git commit -m 'update .gitignore'

参考文章:

http://www.cnblogs.com/kevingrace/p/5690241.html

http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/0013758404317281e54b6f5375640abbb11e67be4cd49e0000

http://www.pfeng.org/archives/840