1. 程式人生 > >Git忽略規則和.gitignore規則不生效的解決辦法

Git忽略規則和.gitignore規則不生效的解決辦法

note 生效 sub cached git 一行 server 自己 原來

Git忽略規則:

在git中如果想忽略掉某個文件,不讓這個文件提交到版本庫中,可以使用修改根目錄中 .gitignore 文件的方法(如果沒有這個文件,則需自己手工建立此文件)。這個文件每一行保存了一個匹配的規則例如:

# 此為註釋 – 將被 Git 忽略

*.sample    # 忽略所有 .sample 結尾的文件
!lib.sample   # 但 lib.sample 除外
/TODO    # 僅僅忽略項目根目錄下的 TODO 文件,不包括 subdir/TODO
build/    # 忽略 build/ 目錄下的所有文件
doc/*.txt   # 會忽略 doc/notes.txt 但不包括 doc/server/arch.txt

.gitignore規則不生效的解決辦法

把某些目錄或文件加入忽略規則,按照上述方法定義後發現並未生效,原因是.gitignore只能忽略那些原來沒有被追蹤的文件,如果某些文件已經被納入了版本管理中,則修改.gitignore是無效的。那麽解決方法就是先把本地緩存刪除(改變成未被追蹤狀態),然後再提交:

git rm -r --cached .    (可以用,這都是我實際工作中的經歷)
git add .
git commit -m ‘update .gitignore‘

Git忽略規則和.gitignore規則不生效的解決辦法