DevOps - 版本控制 - Git

配置

.gitignore 配置

.gitignore 配置文件用於配置不須要加入版本管理的文件,配置好該文件能夠爲咱們的版本管理帶來很大的便利。php

有些時候,你必須把某些文件放到Git工做目錄中,但又不能提交它們,好比保存了數據庫密碼的配置文件啦、微信的安全key了等等,每次 git status 都會顯示 Untracked files ... ,有強迫症的童鞋內心確定不爽。laravel

好在Git考慮到了你們的感覺,這個問題解決起來也很簡單,在Git工做區的根目錄下建立一個特殊的 .gitignore 文件,而後把要忽略的文件名填進去,Git就會自動忽略這些文件。git

不須要從頭寫 .gitignore 文件,GitHub已經爲咱們準備了各類配置文件,只須要組合一下就可使用了。全部配置文件能夠直接在線瀏覽: https://github.com/github/gitignore github

1. 忽略文件的原則是:

  • 忽略操做系統自動生成的文件,好比縮略圖等;
  • 忽略編譯生成的中間文件、可執行文件等,也就是若是一個文件是經過另外一個文件自動生成的,那自動生成的文件就不必放進版本庫,好比Java編譯產生的.class文件;
  • 忽略你本身的帶有敏感信息的配置文件,好比存放口令的配置文件。
舉個例子:

假設你用PHPStorm下進行PHP開發,PHPStrom會自動建立 .idea 目錄, 若是咱們想去忽略掉這個目錄,須要在.gitignore里加入數據庫

# PHPStrom:
.idea/

 

而後,若是實在Mac OS X 下面開發,最好也加上:bootstrap

# MAC:
.DS_Store
# Thumbnails
._*

 

固然,若是你是基於Lravel開發的話,能夠加入:安全

/bootstrap/compiled.php
.env.*.php
.env.php
.env    

 

加上你本身定義的文件,最終獲得一個完整的.gitignore文件,內容以下:微信

# MAC:
.DS_Store
# PHPStrom:
.idea/
#laravel
/bootstrap/compiled.php
.env.*.php
.env.php
.env    

 

最後一步就是把.gitignore也提交到Git,就完成了!ide

2. 配置語法

  • 以斜槓「/」開頭表示目錄;
  • 以星號「*」通配多個字符;
  • 以問號「?」通配單個字符
  • 以方括號「[]」包含單個字符的匹配列表;
  • 以歎號「!」表示不忽略(跟蹤)匹配到的文件或目錄;

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

3. 規則:

  • 規則: fd1/* 

    說明:忽略目錄 fd1 下的所有內容;注意,不論是根目錄下的 /fd1/ 目錄,仍是某個子目錄 /child/fd1/ 目錄,都會被忽略;

  • 規則: /fd1/* 

    說明:忽略根目錄下的 /fd1/ 目錄的所有內容;

  • 規則:

  •  /*  
      !.gitignore  
      !/fw/bin/  
      !/fw/sf/

     

     
      

    說明:忽略所有內容,可是不忽略 .gitignore 文件、根目錄下的 /fw/bin/ 和 /fw/sf/ 目錄;

4. 小結

  • 忽略某些文件時,須要編寫.gitignore;
  • .gitignore 文件自己要放到版本庫裏,而且能夠對.gitignore作版本管理!
  • 關於不知.gitignore裏應該加什麼的,能夠查閱: https://github.com/github/gitignore 

.gitconfig 全局配置

有沒有常常敲錯命令?好比 git status? status 這個單詞真心很差記。

若是敲git st就表示git status,那就簡單多了,固然這種偷懶的辦法咱們是極力同意的。

咱們只須要敲一行命令,告訴Git,之後st就表示status:

$ git config --global alias.st status

 

好了,如今敲 git st 看看效果。

固然還有別的命令能夠簡寫,不少人都用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 參數是全局參數,也就是這些命令在這臺電腦的全部Git倉庫下都有用。

配置一個 git last ,讓其顯示最後一次提交信息:

 

這樣,用git last就能顯示最近一次的提交:

$ git last
commit adca45d317e6d8a4b23f9811c3d7b7f0f180bfe2
Merge: bd6ae48 291bea8
Author: qloog <qloog@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 的效果:

git -lg

 

爲何不早點告訴我?別激動,咱不是爲了多記幾個英文單詞嘛!

配置文件

配置Git的時候,加上 --global 是針對當前用戶起做用的,若是不加,那隻針對當前的倉庫起做用。

配置文件放哪了?每一個倉庫的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:qloog/laravel5-wechat.git
    fetch = +refs/heads/*:refs/remotes/origin/*
[branch "master"]
    remote = origin
    merge = refs/heads/master
[alias]
    last = log -1 別名就在[alias]後面,要刪除別名,直接把對應的行刪掉便可。

 

而當前用戶的Git配置文件放在用戶主目錄下的一個隱藏文件 .gitconfig 中:

$ cat ~/.gitconfig
[alias]
    co = checkout
    ci = commit
    br = branch
    st = status
[user]
    name = Your Name
    email = your@email.com

 

配置別名也能夠直接修改這個文件,若是改錯了,能夠刪掉文件從新經過命令配置。

小結

給Git配置好別名,就能夠輸入命令時偷個懶。咱們鼓勵偷懶。

相關文章
相關標籤/搜索