重要!重要!重要!重要的事情说三遍!大家一定要养成在项目开始就创建 .gitignore 文件的习惯,否则一旦push,处理起来会非常麻烦。
1) .gitignore文件
在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改 .gitignore 文件的方法。
.gitignore 文件创建
touch .gitignore #创建gitignore隱藏文件
vim .gitignore #编辑文件,加入指定文件
示例:这个文件每一行保存了一个匹配的规则
# 此为注释 – 将被 Git 忽略
*.a # 忽略所有 .a 结尾的文件
!lib.a # 但 lib.a 除外
/TODO # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
build/ # 忽略 build/ 目录下的所有文件
doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt
文件.gitignore的格式规范:
A:#为注释
B:可以使用shell所使用的正则表达式来进行模式匹配
C:匹配模式最后跟"/"说明要忽略的是目录
D:使用!取反(例如目录中包含 test.a,并且gitignore文件中包含 *.[oa],如果在文件中加入 !test.a 表明忽略除test.a文件以外的后缀名为.a或者.o的文件)
2、如果已经push了怎么办
有时候在项目开发过程中,想把某些目录或文件加入忽略规则,按照上述方法定义后发现并未生效,原因是.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。那么解决方法就是先把本地缓存删除(改变成未track状态)
git rm -r --cached 文件/文件夹名字
去掉已经托管的文件或者文件夹,然后提交即可。
3、 gitignoreglobal全局忽略文件
掉已经托管在git上的文件:.gitignore配置规则 及其 git rm -r --cached 去_zfoo-CSDN博客