Git 忽略送出 .gitignore
在使用Git的過程中,我們喜歡有的檔案比如日志,臨時檔案,編譯的中間檔案等不要送出到代碼倉庫,這時就要設定相應的忽略規則,來忽略這些檔案的送出。
Git 忽略檔案送出的方法
有三種方法可以實作忽略Git中不想送出的檔案。
在Git項目中定義 .gitignore 檔案
這種方式通過在項目的某個檔案夾下定義 .gitignore 檔案,在該檔案中定義相應的忽略規則,來管理目前檔案夾下的檔案的Git送出行為。
.gitignore 檔案是可以送出到共有倉庫中,這就為該項目下的所有開發者都共享一套定義好的忽略規則。
在 .gitingore 檔案中,遵循相應的文法,在每一行指定一個忽略規則。如:
*.log
*.temp
/vendor
在Git項目的設定中指定排除檔案
這種方式隻是臨時指定該項目的行為,需要編輯目前項目下的
.git/info/exclude
檔案,然後将需要忽略送出的檔案寫入其中。
需要注意的是,這種方式指定的忽略檔案的根目錄是項目根目錄。
定義Git全局的 .gitignore 檔案
除了可以在項目中定義 .gitignore 檔案外,還可以設定全局的 git .gitignore 檔案來管理所有Git項目的行為。這種方式在不同的項目開發者之間是不共享的,是屬于項目之上Git應用級别的行為。
這種方式也需要建立相應的 .gitignore 檔案,可以放在任意位置。然後在使用以下指令配置Git:
git config --global core.excludesfile ~/.gitignore
Git 忽略規則
詳細的忽略規則可以參考官方英文文檔
Git 忽略規則優先級
在 .gitingore 檔案中,每一行指定一個忽略規則,Git 檢查忽略規則的時候有多個來源,它的優先級如下(由高到低):
- 從指令行中讀取可用的忽略規則
- 目前目錄定義的規則
- 父級目錄定義的規則,依次地推
- $GIT_DIR/info/exclude 檔案中定義的規則
- core.excludesfile中定義的全局規則
Git 忽略規則比對文法
在 .gitignore 檔案中,每一行的忽略規則的文法如下:
-
不比對任意檔案,可作為分隔符,可用反斜杠轉義空格
-
的模式辨別注釋,可以使用反斜杠進行轉義# 開頭
-
的模式辨別否定,該檔案将會再次被包含,如果排除了該檔案的父級目錄,則使用 ! 也不會再次被包含。可以使用反斜杠進行轉義! 開頭
-
的模式隻比對檔案夾以及在該檔案夾路徑下的内容,但是不比對該檔案/ 結束
-
的模式比對項目跟目錄/ 開始
- 如果一個模式不包含斜杠,則它比對相對于目前 .gitignore 檔案路徑的内容,如果該模式不在 .gitignore 檔案中,則相對于項目根目錄
-
比對多級目錄,可在開始,中間,結束**
-
通用比對單個字元?
-
通用比對單個字元清單[]
常用比對示例:
-
: 忽略目前路徑下的bin檔案夾,該檔案夾下的所有内容都會被忽略,不忽略 bin 檔案bin/
-
: 忽略根目錄下的bin檔案/bin
-
: 忽略/foo, a/foo, a/b/foo等foo
-
: 忽略a/b, a/x/b, a/x/y/b等ab
-
: 不忽略 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'
轉載請注明出處 Git 忽略送出 .gitignore