一、前言
我们以Android项目为例子,在新建项目的时候我们提交项目到仓库之前,会有一个.gitignore文件用于过滤文件或者文件夹,本人强烈建议在第一次新建的时候把该考虑到的都考虑进去,以免后期团队协作开发的时候引起不必要的麻烦,毕竟,时间就是金钱,哪怕是几分钟的事儿。
不过,很多朋友可能是中途接手项目,项目中的忽略文件不合理,此时此刻,我们第一会想到去修改.gitignore文件去忽略提交仓库的文件,但是发现修改完成后,目标文件还是能够提交的。
所以,我们应该怎样做呢?
二、解决办法
1.首先,我们要清楚,为什么我们在提交仓库之后修改了.gitignore去忽略目标文件不起作用?
原因:.gitignore只能忽略掉那些原来没有被追踪(track)的文件,所以如果有一些文件提交到了git仓库当中,接受了git追踪,那么直接修改.gitignore是无效的。所以建议在第一次提交项目时候,把该考虑到的考虑全。
2.忽略已提交的文件也有很多种不同情况,下面我说说常见的几种:
-
例如说,有些文件已经被提交,但是后期做项目的过程中,我们想要忽略这些文件的跟踪。这些文件在本地磁盘中还想保留着(简单说就是仓库上不会存在被忽略的文件,但是本地项目存在这些文件)
过滤gradle-wrapper.properties本地配置
应用场景如下:
这里我们是在本地配置gradle的distributionUrl,由于每台电脑的gradle路径都不一样(如果电脑名不一样),所以需要忽略掉此文件,并且本地是要保留的。这里 我直接把wrapper整个文件夹直接过滤掉。
操作如下:
git rm --cached -r gradle/wrapper
然后修改项目.gitignore文件添加过滤规则:gradle/wrapper
然后commit
最后push -
还有种情况,在我们已经提交过的一些文件中,在后期由于种种原因发现不需要某个文件,我们想这些文件被彻底删除时候。
操作如下:
git rm somefiles 从本地移除这个文件,并且删除本地缓存
更新gitignore文件,忽略目标文件(somefiles)
然后commit
最后push
三、总结
1.下面我说说rm命令系列的作用和用法与区别:
- rm
单纯的删除本地文件,与git没有任何关系,所以git上是不会有该删除记录的 - git rm
删除git追踪文件,并删除本地文件,git上会保存此次删除记录 - git rm –cached
单单删除git追踪文件,不删除本地文件
2.为什么增加了.gitignore里的规则却没有效果?
- 我在文章开始也简单提到了,那是因为.gitignore文件只能作用于未跟踪的文件(Untracked Files),也就是从来没有被Git记录过的文件。所以要先从Git索引中删除对改文件的追踪,才能使.gitignore文件生效。而删除文件的追踪是git rm,这种做法会将本地的物理文件一并删除。如果想要删除追踪状态而非物理文件,可以使用git rm --cached。
网友评论