在项目中,并不是所有的文件都有保存到版本库中,如日志文件、临时文件、较大的权重文件、工具生成的文件等。
git ignore这是一个java的代码仓库,还没有进行远程控制。
未初始化之前的文件夹
使用 git init -b main 创建main分支,初始化本地文件夹,进行版本控制
生成了.git文件夹进行版本控制
我复制了一个.idea/文件夹,所以现在多了这个文件夹。这个是IDEA的缓存我不希望上传。
提示:此时所有的内容都将被纳入到版本库
创建.gitignore文件,如果有就不用创建了,用文本编辑器打开文件,进行配置。
现在我想忽略 target 和 idea 文件夹
这是修改之前的git status状态
*每项配置独占一行。
*每行内容可以是:文件/目录 的名称、路径 或 他们的模式匹配
查看当前git status状态,上面是还没有添加到.gitignore的对比。
可以看到红色部分已经被忽略了。
如果还想继续忽略 txt文件,一样将文件名添加到.gitignore文件即可。
查看git status状态
可以发现a.txt和b.txt都已经被忽略了,到这里最基本的用法就已经结束啦。
往往在真是的开发场景中,比如微服务项目往往是多个层级目录,并且每个目录都有相同的文件,或者在一个深层目录有一个大文件我们不想上传还有很多复杂的场景。这个时候光靠我们把目录一个个复制到.gitignore文件夹是不够用的。 所以就让我们拾起.gitignore的神器来战胜这些牛马问题吧。
场景一: 除了a.txt,b.txt 我还有上百个以txt结尾的文件在根目录,这些文件我都不想上传到远程仓库。除了一行行复制文件名还有什么更好的办法吗?
当然有,我们可以写一条规则,匹配多个结果,这样就实现了一夫当关万夫莫传的效果。就可以借助我们的模式匹配了,学过正则表达式的小伙伴应该不会陌生。
1 空行 不匹配任何文件,因此常用作分隔符(方便阅读)。
2 # 用于注释,\ 表示转义(如需使用实体\,则要加"")。
3 * 可以匹配任何字符(0或多次),? 可以匹配任何字符(1次)(注意:它们都不可以匹配 / )。
4 / 用于分隔目录:
4.1 当 / 在开头时,表示只从.gitignore文件所在目录开始匹配,否则下级都将匹配。
4.2 当 / 在末尾时,只匹配目录,否则,则同名的目录和文件都将匹配。
5 ! 表示否定,原先被排除的文件,使用 ! 模式后该文件将会被重新被包含。但如果的父级目录被排除了,那么使用 ! 也不会再次被包含(这个是经常容易错的点)。
6 [ ] 通常用于匹配一个字符列表,如:a[mn]z可匹配 amz和anz。
7 ** 用于匹配多级目录,如a/**/b,可以匹配 “a/b”,“a/x/b”,"a/x/y/b"等。
/ax 只能匹配根目录下的ax文件
ax 能匹配根目录下所有目录下的ax,比如/b/ax,c/d/ax等等都能被匹配带到
ax/ 只能匹配ax目录,不能匹配ax文件。
先把之前写的内容注释了,输入* 或者**
git status 查看状态
还记得目录则呢么表示吗?
/结尾表示目录
所有目录就是 */ ,在.gitignore文件输入,git status查看结果。
结果如下,可以发现除了目录文件夹,其他文件没有被忽略。
\git ignore\src\main\java\com\atguigu\gulimall\coupon\GulimallCouponApplication.java
注意:Windows直接复制文件夹文件目录src\test 这个目录划分斜杠不是git中的目录结构划分斜杠,\ 表示转义(如需使用实体\,则要加"")。 需要把 \ 改成 / 在.gitignore文件中。
可能大部分上来就就是直接忽略src文件夹,然后再用感叹号取消这个.java文件了。
这就放错误了啊,铁铁!! 看一下效果。
整个src目录直接就没了啊!!!
圣经重现再读一遍。
! 表示否定,原先被排除的文件,使用 ! 模式后该文件将会被重新被包含。但如果的父级目录被排除了,那么使用 !
也不会再次被包含(这个是经常容易错的点)。
所以这个时候我们需要分步骤来。
先忽略cupon文件夹下的所有文件,然后再取消.java文件。
这个时候需要查看上级目录,再进行忽略
coupon目录结构如下。
\git ignore\src\main\java\com\atguigu\gulimall\coupon
上级目录直到有main目录下面有另一个目录,所以我们也要忽略resource目录
src目录下也有两个目录,所以我们也需要手动忽略test目录
将我们的考虑的写入.gitignore文件如下所示
此时我发现,红色部分没有/src目录!!!心态崩了啊!!!后面才发现#不要跟!一起用,放在行末。
注意: #不要加载 行末,这样会出bug。 可能会误以为后面的一串都是字符,然后识别不了。这个bug搞了一下午,删除# 号和后面的文字就正常了或者单独放一行
此时git status才合乎情理,程序员真的有太多意想不到的bug了,所以大家不要想当然,控制变量法一步一步找!!!
git add . 添加到 暂存区
git status 查看文件状态
此时我们 src目录下的 .java文件终于进来了。
#强制删除缓存
git rm -r -f --cached .
target目录结构如下所示
首先我们实现 只保留target目录,由于target目录与.gitignore目录同级,所以可以直接使用/ *先忽略根目录下的所有文件(不能直接使用*会直接把根目录也忽略),然后使用!保留target文件夹。
git status查看
第一步成功,在考虑如何实现第二部
a{一个字符}z.{后缀名}的所有文件
先要过滤target其他文件夹
/target/*
然后保留 a{一个字符}z.{后缀名}的所有文件
!/target/a?z.*
使用git add . 添加到本地仓库后,使用git status查看文件状态
可以看到只上传了 a9z.txt文件,说明成功了。
git check-ignore -v {文件或者目录路径}
在第四题的条件下,检查target 目录下a.txt文件是否被忽略掉。
git check-ignore target/a.txt
显示了 target/a.txt 就表示被忽略了。
如果想看是具体哪一条规则把它忽略掉了,可以加一个-v
git check-ignore -v target/a.txt
.gitignore:4:/target/* target/a.txt~
表示在 .gitignore 文件的第四行指令:/target/* 忽略了 target/a.txt
66666
方法:加入gitignore -> 删除本地缓存 -> 重新add 。
# 将缓存文件加入gitignore
git rm -r --cached .
git rm -r -f --cached . #强制删除缓存
git add .
git status
方法:从gitignre中移除配置 -> 重新 add。
忽略有道要注意,从子目录来找起
若父目录被忽略,感叹号无力回天
忽略层级划清楚,步步status得出
git check-ignore -v {}
git rm -r --cached .
作者:迷斯特航 https://www.bilibili.com/read/cv19909520 出处:bilibili