git提交之——忽略特殊文件

1.出现的问题

前几天拉代码时,发现项目下的node_modules文件夹消失了,当时也没想那么多,反手就是一个npm install,悠哉游哉的看着屏幕上不断翻滚的一个个字符。

等到包全部安装好了,我又操作了一段时间的代码,准备将更改的代码上传git,这才发现自己闯了多大的祸。

这次的项目里没有配置gitignore文件,也就意味着,我那sourcetreegit图形化工具)的未上传文件达到了惊人的13217个!全部是之前install的包,直接让sourcetree卡死在了那里。提交提交不了,关闭关闭不了。一直提示:

Another git process seems to be running in this repository, 
e.g. an editor opened by ‘git commit’. 
Please make sure all processes are terminated then try again. 
If it still fails, a git process remove the file manually to continue…

这段话的意思翻译过来就是git被另外一个进程占用,确保所有的进程都终止后再进行尝试,其实也就是由于我当时的文件量实在太大,git在使用过程中崩溃了,一些资源被上锁没有释放导致的这个问题。

虽然我有尝试重启sourcetree,不过仍然没有解决问题,只要打开就会卡死。

一般情况下——也就是文件不太多的时候,可以通过删除项目文件夹下的.git目录下的index.lock文件来解决问题。但是因为我本地的文件数量过于庞大,因此即使删除了index.lock文件,sourcetree的进程也会很快被下一个文件给堵塞掉,生成一个新的index.lock文件,简直无解。

2.解决方案

以前从来没有碰到过这种情况的我慌了神,还好身边的同事及时提醒:你是不是没有gitignore文件啊。

gitignore文件——顾名思义,就是在上传git时设置的需要忽略的一些东西,比如编译时生成的临时文件啊、日志啊、install的一些包啊、打包时生成的dist文件啊等等。这些东西如果上传到git中去,被其他人拉取下来之后,可能会与他本地的配置有冲突。

因此,git为我们提供了一个非常简便的办法:git工作区的根目录下创建一个特殊的.gitignore文件,然后把要忽略的文件名填进去,git就会自动忽略这些文件

3.gitignore详解

  • .gitignore忽略文件的原则
  1. 忽略操作系统自动生成的文件,比如缩略图等;
  2. 忽略你自己的带有敏感信息的配置文件,比如存放口令的配置文件;
  3. 忽略编译生成的中间文件、可执行文件等,也就是如果一个文件是通过另一个文件自动生成的,那自动生成的文件就没必要放进版本库,比如Java编译产生的.class文件
  • .gitignore忽略规则的优先级
  1. 从命令行中读取可用的忽略规则
  2. 当前目录定义的规则
  3. 父级目录定义的规则,依次递推
    4.$GIT_DIR/info/exclude文件中定义的规则
  4. core.excludesfile中定义的全局规则
  • .gitignore忽略规则的匹配语法
  1. 空格不匹配任意文件,可作为分隔符,可用反斜杠转义
  1. 以“#”开头的行都会被 Git 忽略。即#开头的文件标识注释,可以使用反斜杠进行转义。
  1. 可以使用标准的glob模式匹配。所谓的glob模式是指shell所使用的简化了的正则表达式。
  1. 以斜杠"/"开头表示目录;
    "/"结束的模式只匹配文件夹以及在该文件夹路径下的内容,但是不匹配该文件;
    "/"开始的模式匹配项目跟目录;
    如果一个模式不包含斜杠,则它匹配相对于当前.gitignore文件路径的内容,
    如果该模式不在 .gitignore 文件中,则相对于项目根目录。
  1. 以星号""通配多个字符,即匹配多个任意字符;
    使用两个星号"
    *" 表示匹配任意中间目录
  1. 以问号"?"通配单个字符,即匹配一个任意字符;
  1. 以方括号"[]"包含单个字符的匹配列表,即匹配任何一个列在方括号中的字符;
  1. 以叹号"!"表示不忽略(跟踪)匹配到的文件或目录,即要忽略指定模式以外的文件或目录,可以在模式前加上惊叹号(!)取反

注意: git 对于 .gitignore配置文件是按行从上到下进行规则匹配的

  • .gitignore常用的几种忽略规则
node_modules    忽略node_modules文件夹 

*.zip           忽略所有.zip结尾的文件

/dist           忽略项目根目录下的dist文件夹,但不包括子目录下的dist文件夹

build/          忽略 build/目录下的所有文件,包括子目录下的文件
  • 特别注意

如果在创建.gitignore文件之前就push了项目,那么即使在.gitignore文件中写入新的过滤规则,这些规则也不会起作用,git仍然会对所有文件进行版本管理。

出现这种问题的原因是git已经开始管理这些文件了,所以无法再通过过滤规则过滤它们。

这种时候可以先把本地缓存删除,然后再提交,具体操作如下:

git rm -r --cached
git add 
git commit -m 'update .gitignore'
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,088评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,715评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,361评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,099评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 60,987评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,063评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,486评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,175评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,440评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,518评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,305评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,190评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,550评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,880评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,152评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,451评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,637评论 2 335