Git 忽略一些文件不加入版本控制

    在git中若是想忽略掉某個文件,不讓這個文件提交到版本庫中,可使用修改 .gitignore 文件的方法。這個文件每一行保存了一個匹配的規則例如:git

# 此爲註釋 – 將被 Git 忽略緩存

            *.a       # 忽略全部 .a 結尾的文件
            !lib.a    # 但 lib.a 除外
            /TODO     # 僅僅忽略項目根目錄下的 TODO 文件,不包括 subdir/TODO
            build/    # 忽略 build/ 目錄下的全部文件ui

            doc/*.txt # 會忽略 doc/notes.txt 但不包括 doc/server/arch.txt.net

    這樣設置了之後 全部的 .pyc 文件都不會添加到版本庫中去。版本控制

    另外 git 提供了一個全局的 .gitignore,你能夠在你的用戶目錄下建立 ~/.gitignoreglobal 文件,以一樣的規則來劃定哪些文件是不須要版本控制的。server

須要執行 git config --global core.excludesfile ~/.gitignoreglobal來使得它生效。ip

其餘的一些過濾條件ci

    * ?:表明任意的一個字符
    * *:表明任意數目的字符
    * {!ab}:必須不是此類型
    * {ab,bb,cx}:表明ab,bb,cx中任一類型便可
    * [abc]:表明a,b,c中任一字符便可get

    * [ ^abc]:表明必須不是a,b,c中任一字符it

    因爲git不會加入空目錄,因此下面作法會致使tmp不會存在 tmp/*             //忽略tmp文件夾全部文件

    改下方法,在tmp下也加一個.gitignore,內容爲
                        *
                        !.gitignore
    還有一種狀況,就是已經commit了,再加入gitignore是無效的,因此須要刪除下緩存
                        git rm -r --cached ignore_file

 

注意: .gitignore只能忽略那些原來沒有被track的文件,若是某些文件已經被歸入了版本管理中,則修改.gitignore是無效的。

    正確的作法是在每一個clone下來的倉庫中手動設置不要檢查特定文件的更改狀況。
    git update-index --assume-unchanged PATH    在PATH處輸入要忽略的文件。

    另外 git 還提供了另外一種 exclude 的方式來作一樣的事情,不一樣的是 .gitignore 這個文件自己會提交到版本庫中去。用來保存的是公共的須要排除的文件。而 .git/info/exclude 這裏設置的則是你本身本地須要排除的文件。 他不會影響到其餘人。也不會提交到版本庫中去。

    .gitignore 還有個有意思的小功能, 一個空的 .gitignore 文件 能夠看成是一個 placeholder 。當你須要爲項目建立一個空的 log 目錄時, 這就變的頗有用。 你能夠建立一個 log 目錄 在裏面放置一個空的 .gitignore 文件。這樣當你 clone 這個 repo 的時候 git 會自動的建立好一個空的 log 目錄了。

 

 

 

1、關於.gitignore 和 excludes
這兩個文件的只針對還沒有提交到配置庫的文件才起做用。而對於已經提交的文件是不起做用的。
因而可知,這兩個文件的初衷是用於排除不但願上傳入庫的文件。像編譯產生的臨時文件等。

可是,咱們常常有這樣一種狀況。
有個文件,咱們必須入庫,你們一塊兒共享,可是呢。每一個人本地的配置又是因本身本地的環境而異。這樣的話,這個文件就很崩潰了。你要入庫,經過.gitignore和excludes都不起做用。每次git status都會提示你修改,你又好上傳。

對於這種狀況,應該使用下面的命令:

git update-index --assume-unchanged FILENAME

這樣,每一個人,從庫上取代碼後,在本身本地都要執行一下上面的這個命令。這樣,之後,你這個文件的修改,git 都會幫你忽略掉。

固然,哪一天,你但願你的修改要提交入庫,那你也必須手動修改一下 這個文件的標誌位:

git update-index --no-assume-unchanged FILENAME


因此。
咱們總結一下,總的流程:仍是像你日常同樣,須要入庫,所有commit 提交,push。而後,因爲這個文件你本地的配置跟別人不同,你須要修改它,但不須要入庫與別人共享。那麼你就執行上面的 git update-index --assume-unchanged 命令來忽略你本地對它的修改。

參考:
http://dancingpenguinsoflight.com/2010/02/git-tip-ignoring-modifications-to-tracked-files/comment-page-1/#comment-125527

相關文章
相關標籤/搜索