在使用Git的過程當中,咱們喜歡有的文件好比日誌,臨時文件,編譯的中間文件等不要提交到代碼倉庫,這時就要設置相應的忽略規則,來忽略這些文件的提交。php
Git 忽略文件提交的方法
有三種方法能夠實現忽略Git中不想提交的文件。html
在Git項目中定義 .gitignore 文件
這種方式經過在項目的某個文件夾下定義 .gitignore 文件,在該文件中定義相應的忽略規則,來管理當前文件夾下的文件的Git提交行爲。python
.gitignore 文件是能夠提交到公有倉庫中,這就爲該項目下的全部開發者都共享一套定義好的忽略規則。git
在 .gitingore 文件中,遵循相應的語法,在每一行指定一個忽略規則。如:sql
*.log *.temp /vendor
在Git項目的設置中指定排除文件
這種方式只是臨時指定該項目的行爲,須要編輯當前項目下的 .git/info/exclude 文件,而後將須要忽略提交的文件寫入其中。緩存
須要注意的是,這種方式指定的忽略文件的根目錄是項目根目錄。markdown
定義Git全局的 .gitignore 文件
除了能夠在項目中定義 .gitignore 文件外,還能夠設置全局的 git .gitignore 文件來管理全部Git項目的行爲。這種方式在不一樣的項目開發者之間是不共享的,是屬於項目之上Git應用級別的行爲。post
這種方式也須要建立相應的 .gitignore 文件,能夠放在任意位置。而後在使用如下命令配置Git:ui
git config --global core.excludesfile ~/.gitignore
Git 忽略規則
詳細的忽略規則能夠參考官方英文文檔spa
Git 忽略規則優先級
在 .gitingore 文件中,每一行指定一個忽略規則,Git 檢查忽略規則的時候有多個來源,它的優先級以下(由高到低):
- 從命令行中讀取可用的忽略規則
- 當前目錄定義的規則
- 父級目錄定義的規則,依次遞推
- $GIT_DIR/info/exclude 文件中定義的規則
- core.excludesfile中定義的全局規則
Git 忽略規則匹配語法
在 .gitignore 文件中,每一行的忽略規則的語法以下:
- 空格不匹配任意文件,可做爲分隔符,可用反斜槓轉義
- # 開頭的文件標識註釋,可使用反斜槓進行轉義
- ! 開頭的模式標識否認,該文件將會再次被包含,若是排除了該文件的父級目錄,則使用 ! 也不會再次被包含。可使用反斜槓進行轉義
- / 結束的模式只匹配文件夾以及在該文件夾路徑下的內容,可是不匹配該文件
- / 開始的模式匹配項目跟目錄
- 若是一個模式不包含斜槓,則它匹配相對於當前 .gitignore 文件路徑的內容,若是該模式不在 .gitignore 文件中,則相對於項目根目錄
- ** 匹配多級目錄,可在開始,中間,結束
- ? 通用匹配單個字符
- [] 通用匹配單個字符列表
經常使用匹配示例:
- bin/: 忽略當前路徑下的bin文件夾,該文件夾下的全部內容都會被忽略,不忽略 bin 文件
- /bin: 忽略根目錄下的bin文件
- /*.c: 忽略 cat.c,不忽略 build/cat.c
- debug/*.obj: 忽略 debug/io.obj,不忽略 debug/common/io.obj 和 tools/debug/io.obj
- **/foo: 忽略/foo, a/foo, a/b/foo等
- a/**/b: 忽略a/b, a/x/b, a/x/y/b等
- !/bin/run.sh: 不忽略 bin 目錄下的 run.sh 文件
- *.log: 忽略全部 .log 文件
- config.php: 忽略當前路徑的 config.php 文件
.gitignore規則不生效
.gitignore只能忽略那些原來沒有被track的文件,若是某些文件已經被歸入了版本管理中,則修改.gitignore是無效的。
解決方法就是先把本地緩存刪除(改變成未track狀態),而後再提交:
git rm -r --cached . git add . git commit -m 'update .gitignore'