git忽略特殊文件_動力節(jié)點(diǎn)Java學(xué)院整理
有些時(shí)候,你必須把某些文件放到Git工作目錄中,但又不能提交它們,比如保存了數(shù)據(jù)庫密碼的配置文件啦,等等,每次git status都會顯示Untracked files ...,有強(qiáng)迫癥的童鞋心里肯定不爽。
好在Git考慮到了大家的感受,這個(gè)問題解決起來也很簡單,在Git工作區(qū)的根目錄下創(chuàng)建一個(gè)特殊的.gitignore文件,然后把要忽略的文件名填進(jìn)去,Git就會自動忽略這些文件。
不需要從頭寫.gitignore文件,GitHub已經(jīng)為我們準(zhǔn)備了各種配置文件,只需要組合一下就可以使用了。所有配置文件可以直接在線瀏覽:https://github.com/github/gitignore
忽略文件的原則是:
1.忽略操作系統(tǒng)自動生成的文件,比如縮略圖等;
2.忽略編譯生成的中間文件、可執(zhí)行文件等,也就是如果一個(gè)文件是通過另一個(gè)文件自動生成的,那自動生成的文件就沒必要放進(jìn)版本庫,比如Java編譯產(chǎn)生的.class文件;
3.忽略你自己的帶有敏感信息的配置文件,比如存放口令的配置文件。
舉個(gè)例子:
假設(shè)你在Windows下進(jìn)行Python開發(fā),Windows會自動在有圖片的目錄下生成隱藏的縮略圖文件,如果有自定義目錄,目錄下就會有Desktop.ini文件,因此你需要忽略Windows自動生成的垃圾文件:
# Windows: Thumbs.db ehthumbs.db Desktop.ini
然后,繼續(xù)忽略Python編譯產(chǎn)生的.pyc、.pyo、dist等文件或目錄:
# Python: *.py[cod] *.so *.egg *.egg-info dist build
加上你自己定義的文件,最終得到一個(gè)完整的.gitignore文件,內(nèi)容如下:
# Windows: Thumbs.db ehthumbs.db Desktop.ini # Python: *.py[cod] *.so *.egg *.egg-info dist build # My configurations: db.ini deploy_key_rsa
最后一步就是把.gitignore也提交到Git,就完成了!當(dāng)然檢驗(yàn).gitignore的標(biāo)準(zhǔn)是git status命令是不是說working directory clean。
使用Windows的童鞋注意了,如果你在資源管理器里新建一個(gè).gitignore文件,它會非常弱智地提示你必須輸入文件名,但是在文本編輯器里“保存”或者“另存為”就可以把文件保存為.gitignore了。
有些時(shí)候,你想添加一個(gè)文件到Git,但發(fā)現(xiàn)添加不了,原因是這個(gè)文件被.gitignore忽略了:
$ git add App.class The following paths are ignored by one of your .gitignore files: App.class Use -f if you really want to add them.
如果你確實(shí)想添加該文件,可以用-f強(qiáng)制添加到Git:
$ git add -f App.class
或者你發(fā)現(xiàn),可能是.gitignore寫得有問題,需要找出來到底哪個(gè)規(guī)則寫錯(cuò)了,可以用git check-ignore命令檢查:
$ git check-ignore -v App.class .gitignore:3:*.class App.class
Git會告訴我們, .gitignore的第3行規(guī)則忽略了該文件,于是我們就可以知道應(yīng)該修訂哪個(gè)規(guī)則。
配置別名
有沒有經(jīng)常敲錯(cuò)命令?比如git status?status這個(gè)單詞真心不好記。
如果敲git st就表示git status那就簡單多了,當(dāng)然這種偷懶的辦法我們是極力贊成的。
我們只需要敲一行命令,告訴Git,以后st就表示status:
$ git config --global alias.st status
好了,現(xiàn)在敲git st看看效果。
當(dāng)然還有別的命令可以簡寫,很多人都用co表示checkout,ci表示commit,br表示branch:
$ git config --global alias.co checkout $ git config --global alias.ci commit $ git config --global alias.br branch
以后提交就可以簡寫成:
$ git ci -m "bala bala bala..."
--global參數(shù)是全局參數(shù),也就是這些命令在這臺電腦的所有Git倉庫下都有用。
命令git reset HEAD file可以把暫存區(qū)的修改撤銷掉(unstage),重新放回工作區(qū)。既然是一個(gè)unstage操作,就可以配置一個(gè)unstage別名:
$ git config --global alias.unstage 'reset HEAD'
當(dāng)你敲入命令:
$ git unstage test.py
實(shí)際上Git執(zhí)行的是:
$ git reset HEAD test.py
配置一個(gè)git last,讓其顯示最后一次提交信息:
$ git config --global alias.last 'log -1'
這樣,用git last就能顯示最近一次的提交:
$ git last commit adca45d317e6d8a4b23f9811c3d7b7f0f180bfe2 Merge: bd6ae48 291bea8 Author: Michael Liao <askxuefeng@gmail.com> Date: Thu Aug 22 22:49:22 2013 +0800 merge & fix hello.py
甚至還有人喪心病狂地把lg配置成了:
git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit"
來看看git lg的效果:
為什么不早點(diǎn)告訴我?別激動,咱不是為了多記幾個(gè)英文單詞嘛!
配置文件
配置Git的時(shí)候,加上--global是針對當(dāng)前用戶起作用的,如果不加,那只針對當(dāng)前的倉庫起作用。
配置文件放哪了?每個(gè)倉庫的Git配置文件都放在.git/config文件中:
$ cat .git/config [core] repositoryformatversion = 0 filemode = true bare = false logallrefupdates = true ignorecase = true precomposeunicode = true [remote "origin"] url = git@github.com:michaelliao/learngit.git fetch = +refs/heads/*:refs/remotes/origin/* [branch "master"] remote = origin merge = refs/heads/master [alias] last = log -1
別名就在[alias]后面,要刪除別名,直接把對應(yīng)的行刪掉即可。
而當(dāng)前用戶的Git配置文件放在用戶主目錄下的一個(gè)隱藏文件.gitconfig中:
$ cat .gitconfig [alias] co = checkout ci = commit br = branch st = status [user] name = Your Name email = your@email.com
配置別名也可以直接修改這個(gè)文件,如果改錯(cuò)了,可以刪掉文件重新通過命令配置。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Ubuntu Server Rsync服務(wù)端與Windows cwRsync客戶端數(shù)據(jù)同步配置方法
這篇文章主要介紹了Ubuntu Server Rsync服務(wù)端與Windows cwRsync客戶端數(shù)據(jù)同步配置方法,需要的朋友可以參考下2015-07-07Linux搭建syslog日志服務(wù)器的詳細(xì)過程
這篇文章主要介紹了Linux搭建syslog日志服務(wù)器的詳細(xì)過程,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-05-05虛擬主機(jī)應(yīng)該如何解決電信網(wǎng)通間互聯(lián)互通
電信和網(wǎng)通兩大基礎(chǔ)網(wǎng)絡(luò),人為地割裂了整個(gè)中國的網(wǎng)絡(luò)。無論是選擇把網(wǎng)站托管在電信、還是網(wǎng)通,都等于是在拒絕處于另外一個(gè)網(wǎng)絡(luò)中的客戶,因?yàn)閷?shí)在太慢了2011-10-10windows2008系統(tǒng)中rsync計(jì)劃任務(wù)返回0x1問題處理
本文給大家分享的是小編在給windows2008配置rsync同步的過程中遇到的一個(gè)問題,在win03系統(tǒng)下可以正常返回0x0,結(jié)果到了win08系統(tǒng)中就變成了0x1,雖然也同步成功了,但是作為一個(gè)完美主義強(qiáng)迫癥患者,堅(jiān)決不能忍,經(jīng)過一番查證,找到了解決辦法,分享給大家2017-04-04手把手教你低成本獲取AlphaSSL通配符泛域名SSL證書2024仍可用
AlphaSSL 是著名數(shù)字證書認(rèn)證機(jī)構(gòu)和SSL證書簽發(fā)商 GlobalSign 旗下的證書品牌,這篇文章主打手把手教你低成本獲取AlphaSSL通配符泛域名SSL證書,需要的朋友可以參考下2024-02-02CentOS上搭建PHP服務(wù)器環(huán)境的步驟與方法
這篇文章主要介紹了CentOS上搭建PHP服務(wù)器環(huán)境的步驟與方法,簡單分析了CentOS安裝Apache、mysql及php的步驟與相關(guān)操作命令,并給出了php測試實(shí)例,需要的朋友可以參考下2016-10-10