版权声明:本文为博主原创文章,未经博主允许不得转载。(Copyright © https://blog.csdn.net/s_gy_zetrov. All Rights Reserved) https://blog.csdn.net/S_gy_Zetrov/article/details/84553276
git中.gitignore
文件不起作用的解决
本篇内容实际上很多博客已经提到了,但是我想说的,是经过实际测试有效的解决方法。
什么情况下.gitignore
文件会失效
当你已经使用git来track了一些不想要的文件时,这些文件是无法被.gitignore
文件忽略的。
比如:你的git仓库中有3个文件,A.tex
, B.log
, C.aux
。如果你在建立仓库时没有添加.gitignore
文件,而是选择了直接commit -am
,则后续再添加.gitignore
文件如
############################################
## LATEX TEMPORARY FILES
############################################
*.log
*.aux
时,git是不会去忽略*.log
或*.aux
文件的。原因就是这些文件已经被git给cache了,也就是被缓存了。所以解决方案就是让git重新去缓存整个仓库,把不想要的文件统统通过重新缓存这个操作来“丢”掉。
网上普遍的解决办法(测试通过,有效)
注意命令最后的英文句号是要带上的!
git rm -r --cached .
git add .
git commit -m 'updated .gitignore file'
这样3条命令结束后,git就会将你不想要的文件,从缓存中丢掉,也就是终于使.gitignore
文件生效。