Git忽略規則.gitignore梳理

對於常用Git的朋友來講,.gitignore配置必定不會陌生。廢話不說多了,接下來就來講說這個.gitignore的使用。ios

首先要強調一點,這個文件的完整文件名就是".gitignore",注意最前面有個「.」。
通常來講每一個Git項目中都須要一個「.gitignore」文件,這個文件的做用就是告訴Git哪些文件不須要添加到版本管理中。實際項目中,不少文件都是不須要版本管理的,好比Python的.pyc文件和一些包含密碼的配置文件等等。這個文件的內容是一些規則,Git會根據這些規則來判斷是否將文件添加到版本控制中。git

下面咱們看看經常使用的規則:
1)/mtk/ 過濾整個文件夾
2)*.zip 過濾全部.zip文件
3)/mtk/do.c 過濾某個具體文件github

很簡單吧,被過濾掉的文件就不會出如今git倉庫中(gitlab或github)了,固然本地庫中還有,只是push的時候不會上傳。
須要注意的是,gitignore還能夠指定要將哪些文件添加到版本管理中:
1)!*.zip
2)!/mtk/one.txt緩存

惟一的區別就是規則開頭多了一個感嘆號,Git會將知足這類規則的文件添加到版本管理中。
爲何要有兩種規則呢?想象一個場景:假如咱們只須要管理/mtk/目錄中的one.txt文件,這個目錄中的其餘文件都不須要管理,那麼咱們就須要使用:
1)/mtk/
2)!/mtk/one.txt
假設咱們只有過濾規則,而沒有添加規則,那麼咱們就須要把/mtk/目錄下除了one.txt之外的全部文件都寫出來!ide

最後須要強調的一點是,若是你不慎在建立.gitignore文件以前就push了項目,那麼即便你在.gitignore文件中寫入新的過濾規則,這些規則也不會起做用,Git仍然會對全部文件進行版本管理。
簡單來講,出現這種問題的緣由就是Git已經開始管理這些文件了,因此你沒法再經過過濾規則過濾它們。所以必定要養成在項目開始就建立.gitignore文件的習慣,不然一旦push,處理起來會很是麻煩。gitlab

.gitignore配置文件用於配置不須要加入版本管理的文件,配置好該文件能夠爲版本管理帶來很大的便利,如下是對於配置.gitignore的一些心得記錄:
1)配置語法:
以斜槓「/」開頭表示目錄;
以星號「*」通配多個字符;
以問號「?」通配單個字符
以方括號「[]」包含單個字符的匹配列表;
以歎號「!」表示不忽略(跟蹤)匹配到的文件或目錄;學習

此外,git 對於 .ignore 配置文件是按行從上到下進行規則匹配的,意味着若是前面的規則匹配的範圍更大,則後面的規則將不會生效;ui

2)示例說明
a)規則:fd1/
說明:忽略目錄 fd1 下的所有內容;注意,不論是根目錄下的 /fd1/ 目錄,仍是某個子目錄 /child/fd1/ 目錄,都會被忽略;
b)規則:/fd1/

說明:忽略根目錄下的 /fd1/ 目錄的所有內容;
c)規則:
/*
!.gitignore
!/fw/bin/
!/fw/sf/
說明:忽略所有內容,可是不忽略 .gitignore 文件、根目錄下的 /fw/bin/ 和 /fw/sf/ 目錄;命令行

其實,須要清除的一點是:
有三種方法能夠實現過濾掉Git裏不想上傳的文件,這三種方法都能達到目的,只不過適用情景不同。版本控制

1)第一種方法
針對單一工程排除文件,這種方式會讓這個工程的全部修改者在克隆代碼的同時,也能克隆到過濾規則,而不用本身再寫一份,這就能保證全部修改者應用的都是同一份規則,而不是張三本身有一套過濾規則,李四又使用另外一套過濾規則,我的比較喜歡這個。配置步驟以下:

在工程根目錄下創建.gitignore文件,將要排除的文件或目錄 寫到.gitignore這個文件中,其中有兩種寫入方法。
a)使用命令行增長排除文件
排除以.class結尾的文件 echo 「*.class」 >.gitignore (>> 是在文件尾增長,> 是刪除已經存在的內容再增長),以後會在當前目錄下生成一個.gitignore的文件。
排除bin目錄下的文件 echo 「bin/」 >.gitignore
b)最方便的辦法是,用記事本打開,增長鬚要排除的文件或目錄,一行增長一個,例如:

.class
.apk
bin/
gen/
.settings/
proguard/

2)第二種方法
全局設置排除文件,這會在全局起做用,只要是Git管理的工程,在提交時都會自動排除不在控制範圍內的文件或目錄。這種方法對開發者來講,比較省事,只要一次全局配置,不用每次創建工程都要配置一遍過濾規則。可是這不保證其餘的開發者在克隆你的代碼後,他們那邊的規則跟你的是同樣的,這就帶來了代碼提交過程當中的各類衝突問題。
配置步驟以下:
a)像方法(1)同樣,也須要創建一個.gitignore文件,把要排除的文件寫進去。
b)但在這裏,咱們不規定必定要把.gitnore文件放到某個工程下面,而是任何地方,好比咱們這裏放到了Git默認的Home路徑下,好比:/home/wangshibo/hqsb_ios
c)使用命令方式能夠配置全局排除文件 git config --global core.excludesfile ~/.gitignore,你會發如今~/.gitconfig文件中會出現excludesfile = /home/wangshibo/hqsb_ios/.gitignore。
說明Git把文件過濾規則應用到了Global的規則中。

3)第三種方法
單個工程設置排除文件,在工程目錄下找到.git/info/exclude,把要排除的文件寫進去:

.class
.apk
bin/
gen/
.settings/
proguard/

這種方法就不提倡了,只能針對單一工程配置,並且還不能將過濾規則同步到其餘開發者,跟方法(1)(2)比較起來沒有一點優點。

------------------------Git忽略規則及.gitignore規則不生效的解決辦法-----------------------------
在git中若是想忽略掉某個文件,不讓這個文件提交到版本庫中,可使用修改根目錄中 .gitignore 文件的方法(如無,則需本身手工創建此文件)。這個文件每一行保存了一個匹配的規則例如:

此爲註釋 – 將被 Git 忽略

.a # 忽略全部 .a 結尾的文件
!lib.a # 但 lib.a 除外
/TODO # 僅僅忽略項目根目錄下的 TODO 文件,不包括 subdir/TODO
build/ # 忽略 build/ 目錄下的全部文件
doc/
.txt # 會忽略 doc/notes.txt 但不包括 doc/server/arch.txt
規則很簡單,不作過多解釋,可是有時候在項目開發過程當中,忽然心血來潮想把某些目錄或文件加入忽略規則,按照上述方法定義後發現並未生效,緣由是.gitignore只能忽略那些原來沒有被track的文件,若是某些文件已經被歸入了版本管理中,則修改.gitignore是無效的。那麼解決方法就是先把本地緩存刪除(改變成未track狀態),而後再提交:

git rm -r --cached .
git add .
git commit -m 'update .gitignore'

注意:
不要誤解了 .gitignore 文件的用途,該文件只能做用於 Untracked Files,也就是那些歷來沒有被 Git 記錄過的文件(自添加之後,從未 add 及 commit 過的文件)。
若是文件曾經被 Git 記錄過,那麼.gitignore 就對它們徹底無效。
當你發現本身的才華撐不起野心時,就請安靜下來學習吧

相關文章
相關標籤/搜索