Git和.gitignore

时间:2021-09-06 19:04:14

http://blog.csdn.net/cscmaker/article/details/8553980

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

# 此为注释 – 将被 Git 忽略

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

规则很简单,不做过多解释,但是有时候在项目开发过程中,突然心血来潮想把某些目录或文件加入忽略规则,按照上述方法定义后发现并未生效,原因是.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。那么解决方法就是先把本地缓存删除(改变成未track状态),然后再提交:

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

那里这里说到一个.gitignore的文件,就是拿来声明哪些文件或文件夹不需要用Git来跟踪的。
不过刚开始使用Git时,会遇到的即使加入.gitignore的文件,但Git依然会进行跟踪,那么这里得分两种情况来看了:
1、如果该文件(夹)已git add进库,那么此时即使你在.gitignore声明,该文件依旧会进行跟踪,需要通过命令将其删除:
git rm –cached -r <path>
2、如果该文件(夹)没有git add进库,那么此时你可以提前在.gitignore进行声名,这样就可以不让Git不跟踪了