美文网首页Android日记Android知识Android开发经验谈
git使用随笔:如何忽略已提交到仓库的文件或者文件夹

git使用随笔:如何忽略已提交到仓库的文件或者文件夹

作者: 码农大表哥 | 来源:发表于2017-07-27 11:45 被阅读65次

    一、前言

    我们以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。

    相关文章

      网友评论

        本文标题:git使用随笔:如何忽略已提交到仓库的文件或者文件夹

        本文链接:https://www.haomeiwen.com/subject/watzkxtx.html