1. 创建 .gitignore
文件添加忽略信息
在Git项目中你可以通过创建.gitignore
文件,在该文件去添加一些你不想被Git跟踪管理的文件或者目录。通过常该文件一般放在Git项目的根目录下,当然也可以在任何子目录中存在。该文件的忽略范围是当前目录及以下子目录。
示例:
HELP.md
target/
!.mvn/wrapper/maven-wrapper.jar #!表示不忽略
!**/src/main/**
!**/src/test/**
### STS ###
.classpath
.project
.settings
### IntelliJ IDEA ###
.idea
*.iml
### VS Code ###
.vscode/
也可以在文件中添加 .gitignore 表示忽略自己,然当也可以不添加让Git管理这个忽略文件。
2. 如何忽略某个已提交被Git跟踪管理的文件?
有时候会有这样的需求,有一个已经被Git仓库跟踪管理的文件,你想要忽略它并从Git仓库中删除它,不再被Git仓库管理,但是又想在本保留这个文件(比如IDEA里面的 .iml 或是eclipse 里面的 .project)。但此时你在.gitignore
文件中添加这个文件不会生效,因为已经被跟踪的文件是不能被忽略的。
解决办法: 原理就是删除Git仓库中的文件提交一个新的版本,在.gitignore
中添加该文件完成。
# 比如忽略xxxx.java文件
# 1. 从暂存区删除xxxx.java, --cached 仅从暂存区删除,不删除工作区的文件,表示该文件还存在在磁盘中
git rm xxxx.java --cached
# 2. 提交一个版本
git commit -m ‘删除xxxx.java’
# 3. 在 .gitignore 中加入该文件配置
当然了,你也可以把文件拷贝出去,再删除文件,提交版本,然后在把文件拷贝回来,添加 .gitignore
配置都行。
方法还挺多的。
实验:
- 这里有个git仓库,有3个文件已经被git管理,现在想忽略
file2.txt
.gitignore
文件内容。忽略了自己
- a. 查看仓库状态,没有任何改动
b.从暂存区中删除file2.txt
,有两条file2.txt的记录,第一表示已经从git暂存区中删除,第二条表示工作工作区中file2.txt处于未被跟踪状态
c.提交一个版本,表示从仓库中删除文件
d.再次查看仓库状态,只有一个未被Git跟踪的文件
3.在.gitignore
文件中添加file2.txt
4.在查看仓库状态file2.txt
已经不存在了,即使再对file2.txt文件内容进行修改,依然不会被跟踪到
5 . 本地的file2.txt文件还在,忽略成功
关于Git的相关命令可以参考 Git常用命令学习笔记…