关于Git中的忽略.gitignore

常规忽略方法:
在git中如果想忽略掉某个文件,不让这个文件提交到版本库中,可以使用修改 .gitignore 文件的方法。
这个文件每一行保存了一个匹配的规则如:

# 注释符号 注释本条忽略规则
*.a # 忽略所有 .a 结尾的文件
!test.bak # 但 test.bak 除外
/bak #忽略项目根目录下的bak文件,不包括 subdir/bak
bak/ # 忽略 bak/ 目录下的所有文件
doc/*.txt # 忽略 doc/test.txt 但不包括 doc/server/test.txt

正则符号(高级用法):

* ?:代表任意的一个字符
* *:代表任意数目的字符
* {!ab}:必须不是此类型
* {ab,bb,cx}:代表ab,bb,cx中任一类型即可
* [abc]:代表a,b,c中任一字符即可
* [ ^abc]:代表必须不是a,b,c中任一字符

由于git不会加入空目录,所以下面做法会导致tmp不会存在 tmp/* //忽略tmp文件夹所有文件
改下方法,在tmp下也加一个.gitignore,内容为

*
!.gitignore

有一种情况,就是已经commit了,再加入gitignore是无效的,所以需要删除下缓存

git rm -r --cached ignore_file

全局忽略:
从此之外git 提供了一个全局的 .gitignore,你可以在你的用户目录下创建 ~/.gitignoreglobal 文件,以同样的规则来定义须要忽略的文件、目录等。
全局忽略需要执行 git config --global core.excludesfile ~/.gitignoreglobal来使其生效。

强制忽略:
.gitignore只能忽略那些原来没有被track的文件,如果某些文件已经被纳入了版本管理中,则修改.gitignore是无效的。
正确的做法是在每个clone下来的仓库中手动设置不要检查特定文件的更改情况。

git update-index --assume-unchanged PATH #在PATH处输入要忽略的文件。

另外Git还提供了另一种 exclude 的方式来做同样的事情,不同的是 .gitignore 这个文件本身会提交到版本库中去。
用来保存的是公共的需要排除的文件。
而 .git/info/exclude 这里设置的则是你自己本地需要排除的文件。
他不会影响到其他人。也不会提交到版本库中去。

.gitignore还有个有意思的小功能,一个空的.gitignore文件可以当作是一个placeholder 。
当你需要为项目创建一个空的log目录时, 这就变的很有用。
你可以创建一个temp目录 在里面放置一个空的 .gitignore 文件。
这样当你clone这个Repo的时候Git会自动的创建好一个空的temp目录了。

Continue reading...



about me

  • 陶之11's Blog Name:陶之11 OICQ:14779023 Site:Pao11.com

分类

快捷入口