git .ignore配置
- .ignore使用场景
- 新项目中.gitignore用法
- 1 初始化生成.git文件夹
- 2 git status 查看当前文件夹状态
- 3 创建.ignore文件 忽略不想上传的文件
- 4 编辑.gitignore文件 git status查看是否生效
- .gitignore进阶用法
- 模式匹配
- 模式匹配例题练习
- 1 忽略所有的内容
- 2 忽略所有目录
- 3 忽略src目录下所有内容,除了GulimallCouponApplication.java文件
- 换个写法
- 4 只保留target目录下的a{一个字符}z.{后缀名}的所有文件
- 检查ignore规则是否有效?
- 已有过版本追踪的文件如何忽略?
- 恢复文件的版本追踪
- 总结
- 视频学习
.ignore使用场景
在项目中,并不是所有的文件都有保存到版本库中,如日志文件、临时文件、较大的权重文件、工具生成的文件等。
新项目中.gitignore用法
git ignore这是一个java的代码仓库,还没有进行远程控制。
1 初始化生成.git文件夹
未初始化之前的文件夹
使用 git init -b main 创建main分支,初始化本地文件夹,进行版本控制
生成了.git文件夹进行版本控制
2 git status 查看当前文件夹状态
我复制了一个.idea/文件夹,所以现在多了这个文件夹。这个是IDEA的缓存我不希望上传。
提示:此时所有的内容都将被纳入到版本库
3 创建.ignore文件 忽略不想上传的文件
创建.gitignore文件,如果有就不用创建了,用文本编辑器打开文件,进行配置。
4 编辑.gitignore文件 git status查看是否生效
现在我想忽略 target 和 idea 文件夹
这是修改之前的git status状态
*每项配置独占一行。
*每行内容可以是:文件/目录 的名称、路径 或 他们的模式匹配
查看当前git status状态,上面是还没有添加到.gitignore的对比。
可以看到红色部分已经被忽略了。
如果还想继续忽略 txt文件,一样将文件名添加到.gitignore文件即可。
查看git status状态
可以发现a.txt和b.txt都已经被忽略了,到这里最基本的用法就已经结束啦。
.gitignore进阶用法
往往在真是的开发场景中,比如微服务项目往往是多个层级目录,并且每个目录都有相同的文件,或者在一个深层目录有一个大文件我们不想上传还有很多复杂的场景。这个时候光靠我们把目录一个个复制到.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文件。
模式匹配例题练习
1 忽略所有的内容
先把之前写的内容注释了,输入* 或者**
git status 查看状态
2 忽略所有目录
还记得目录则呢么表示吗?
/结尾表示目录
所有目录就是 */ ,在.gitignore文件输入,git status查看结果。
结果如下,可以发现除了目录文件夹,其他文件没有被忽略。
3 忽略src目录下所有内容,除了GulimallCouponApplication.java文件
这个是java文件的目录结构。
\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 .
使用/**/代替多级目录,结果还是一样的
4 只保留target目录下的a{一个字符}z.{后缀名}的所有文件
target目录结构如下所示
首先我们实现 只保留target目录,由于target目录与.gitignore目录同级,所以可以直接使用/ *先忽略根目录下的所有文件(不能直接使用*会直接把根目录也忽略),然后使用!保留target文件夹。
git status查看
第一步成功,在考虑如何实现第二部
a{一个字符}z.{后缀名}的所有文件
先要过滤target其他文件夹
/target/*
然后保留 a{一个字符}z.{后缀名}的所有文件
!/target/a?z.*
使用git add . 添加到本地仓库后,使用git status查看文件状态
可以看到只上传了 a9z.txt文件,说明成功了。
检查ignore规则是否有效?
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