什么是Git?
Git(讀音為/g?t/。)是一個(gè)開源的分布式版本控制系統(tǒng)害碾,可以有效、高速的處理從很小到非常大的項(xiàng)目版本管理赦拘。 Git 是 Linus Torvalds 為了幫助管理 Linux 內(nèi)核開發(fā)而開發(fā)的一個(gè)開放源碼的版本控制軟件慌随。
Git是一個(gè)開源的分布式版本控制系統(tǒng),用于敏捷高效地處理任何或小或大的項(xiàng)目躺同。
Git 是 Linus Torvalds 為了幫助管理 Linux 內(nèi)核開發(fā)而開發(fā)的一個(gè)開放源碼的版本控制軟件阁猜。
Git 與常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版本庫的方式蹋艺,不必服務(wù)器端軟件支持剃袍。
Git是目前世界上最先進(jìn)的分布式版本控制系統(tǒng)(沒有之一)。
Git 與 SVN 區(qū)別
GIT不僅僅是個(gè)版本控制系統(tǒng)捎谨,它也是個(gè)內(nèi)容管理系統(tǒng)(CMS),工作管理系統(tǒng)等民效。
如果你是一個(gè)具有使用SVN背景的人隘击,你需要做一定的思想轉(zhuǎn)換,來適應(yīng)GIT提供的一些概念和特征研铆。
Git 與 SVN 區(qū)別點(diǎn):
1埋同、GIT是分布式的,SVN不是:這是GIT和其它非分布式的版本控制系統(tǒng)棵红,例如SVN凶赁,CVS等,最核心的區(qū)別逆甜。
2虱肄、GIT把內(nèi)容按元數(shù)據(jù)方式存儲(chǔ),而SVN是按文件:所有的資源控制系統(tǒng)都是把文件的元信息隱藏在一個(gè)類似.svn,.cvs等的文件夾里交煞。
3咏窿、GIT分支和SVN的分支不同:分支在SVN中一點(diǎn)不特別,就是版本庫中的另外的一個(gè)目錄素征。
4集嵌、GIT沒有一個(gè)全局的版本號,而SVN有:目前為止這是跟SVN相比GIT缺少的最大的一個(gè)特征御毅。
5根欧、GIT的內(nèi)容完整性要優(yōu)于SVN:GIT的內(nèi)容存儲(chǔ)使用的是SHA-1哈希算法。這能確保代碼內(nèi)容的完整性端蛆,確保在遇到磁盤故障和網(wǎng)絡(luò)問題時(shí)降低對版本庫的破壞凤粗。
集中式:
集中型將所有數(shù)據(jù)集中存放在服務(wù)器當(dāng)中,有便于管理的優(yōu)點(diǎn)今豆。但 是一旦開發(fā)者所處的環(huán)境不能連接服務(wù)器嫌拣,就無法獲取最新的源代碼, 開發(fā)也就幾乎無法進(jìn)行呆躲。服務(wù)器宕機(jī)時(shí)也是同樣的道理异逐,而且萬一服務(wù) 器故障導(dǎo)致數(shù)據(jù)消失,恐怕開發(fā)者就再也見不到最新的源代碼了歼秽。
分布式:
如下圖所示应役,GitHub將 倉庫 Fork給了每一個(gè)用戶情组。Fork就是將 GitHub的某個(gè)特定倉庫復(fù)制到 自己的賬戶下燥筷。Fork出的倉庫與原倉庫是兩個(gè)不同的倉庫,開發(fā)者可以隨意編輯院崇。
Git 安裝配置
在使用Git前我們需要先安裝 Git肆氓。Git 目前支持 Linux/Unix、Solaris底瓣、Mac和 Windows 平臺(tái)上運(yùn)行谢揪。
Git 各平臺(tái)安裝包下載地址為:http://git-scm.com/downloads
在Linux上安裝Git
首先蕉陋,你可以試著輸入git,看看系統(tǒng)有沒有安裝Git:
$ git
The program 'git' is currently not installed. You can install it by typing:
sudo apt-get install git
像上面的命令拨扶,有很多Linux會(huì)友好地告訴你Git沒有安裝凳鬓,還會(huì)告訴你如何安裝Git。
如果你碰巧用Debian或Ubuntu Linux患民,通過一條sudo apt-get install git就可以直接完成Git的安裝缩举,非常簡單。
老一點(diǎn)的Debian或Ubuntu Linux匹颤,要把命令改為sudo apt-get install git-core仅孩,因?yàn)橐郧坝袀€(gè)軟件也叫GIT(GNU Interactive Tools),結(jié)果Git就只能叫g(shù)it-core了印蓖。由于Git名氣實(shí)在太大辽慕,后來就把GNU Interactive Tools改成gnuit,git-core正式改為git赦肃。
如果是其他Linux版本溅蛉,可以直接通過源碼安裝。先從Git官網(wǎng)下載源碼他宛,然后解壓温艇,依次輸入:./config,make堕汞,sudo make install這幾個(gè)命令安裝就好了勺爱。
在Mac OS X上安裝Git
如果你正在使用Mac做開發(fā),有兩種安裝Git的方法讯检。
一是安裝homebrew琐鲁,然后通過homebrew安裝Git,具體方法請參考homebrew的文檔:http://brew.sh/人灼。
第二種方法更簡單围段,也是推薦的方法,就是直接從AppStore安裝Xcode投放,Xcode集成了Git奈泪,不過默認(rèn)沒有安裝,你需要運(yùn)行Xcode灸芳,選擇菜單“Xcode”->“Preferences”涝桅,在彈出窗口中找到“Downloads”,選擇“Command Line Tools”烙样,點(diǎn)“Install”就可以完成安裝了冯遂。
在Windows上安裝Git
在Windows上使用Git,可以從Git官網(wǎng)直接下載安裝程序谒获,(網(wǎng)速慢的同學(xué)請移步國內(nèi)鏡像)蛤肌,然后按默認(rèn)選項(xiàng)安裝即可壁却。
安裝完成后,在開始菜單里找到“Git”->“Git Bash”裸准,蹦出一個(gè)類似命令行窗口的東西展东,就說明Git安裝成功!
安裝完成后炒俱,還需要最后一步設(shè)置琅锻,在命令行輸入:
$ git config --global user.name "Your Name"
$ git config --global user.email "email@example.com"
因?yàn)镚it是分布式版本控制系統(tǒng),所以向胡,每個(gè)機(jī)器都必須自報(bào)家門:你的名字和Email地址恼蓬。你也許會(huì)擔(dān)心,如果有人故意冒充別人怎么辦僵芹?這個(gè)不必?fù)?dān)心处硬,首先我們相信大家都是善良無知的群眾,其次拇派,真的有冒充的也是有辦法可查的荷辕。
注意git config命令的--global參數(shù),用了這個(gè)參數(shù)件豌,表示你這臺(tái)機(jī)器上所有的Git倉庫都會(huì)使用這個(gè)配置疮方,當(dāng)然也可以對某個(gè)倉庫指定不同的用戶名和Email地址。
Git 配置
Git 提供了一個(gè)叫做 git config 的工具茧彤,專門用來配置或讀取相應(yīng)的工作環(huán)境變量骡显。
這些環(huán)境變量,決定了 Git 在各個(gè)環(huán)節(jié)的具體工作方式和行為曾掂。這些變量可以存放在以下三個(gè)不同的地方:
/etc/gitconfig 文件:系統(tǒng)中對所有用戶都普遍適用的配置惫谤。若使用 git config 時(shí)用 --system 選項(xiàng),讀寫的就是這個(gè)文件珠洗。
~/.gitconfig 文件:用戶目錄下的配置文件只適用于該用戶溜歪。若使用 git config 時(shí)用 --global 選項(xiàng),讀寫的就是這個(gè)文件许蓖。
當(dāng)前項(xiàng)目的 Git 目錄中的配置文件(也就是工作目錄中的 .git/config 文件):這里的配置僅僅針對當(dāng)前項(xiàng)目有效蝴猪。每一個(gè)級別的配置都會(huì)覆蓋上層的相同配置,所以 .git/config 里的配置會(huì)覆蓋 /etc/gitconfig 中的同名變量膊爪。
在 Windows 系統(tǒng)上自阱,Git 會(huì)找尋用戶主目錄下的 .gitconfig 文件。主目錄即 $HOME 變量指定的目錄蚁飒,一般都是 C:\Documents and Settings\$USER动壤。
此外萝喘,Git 還會(huì)嘗試找尋 /etc/gitconfig 文件淮逻,只不過看當(dāng)初 Git 裝在什么目錄琼懊,就以此作為根目錄來定位。
用戶信息
配置個(gè)人的用戶名稱和電子郵件地址:
$ git config --global user.name "runoob"
$ git config --global user.email test@runoob.com
如果用了 --global 選項(xiàng)爬早,那么更改的配置文件就是位于你用戶主目錄下的那個(gè)哼丈,以后你所有的項(xiàng)目都會(huì)默認(rèn)使用這里配置的用戶信息。
如果要在某個(gè)特定的項(xiàng)目中使用其他名字或者電郵筛严,只要去掉 --global 選項(xiàng)重新配置即可醉旦,新的設(shè)定保存在當(dāng)前項(xiàng)目的 .git/config 文件里。
文本編輯器
設(shè)置Git默認(rèn)使用的文本編輯器, 一般可能會(huì)是 Vi 或者 Vim桨啃。如果你有其他偏好车胡,比如 Emacs 的話,可以重新設(shè)置::
$ git config --global core.editor emacs
差異分析工具
還有一個(gè)比較常用的是照瘾,在解決合并沖突時(shí)使用哪種差異分析工具匈棘。比如要改用 vimdiff 的話:
$ git config --global merge.tool vimdiff
Git 可以理解 kdiff3,tkdiff析命,meld主卫,xxdiff,emerge鹃愤,vimdiff簇搅,gvimdiff,ecmerge软吐,和 opendiff 等合并工具的輸出信息瘩将。
當(dāng)然,你也可以指定使用自己開發(fā)的工具凹耙,具體怎么做可以參閱第七章鸟蟹。
查看配置信息
要檢查已有的配置信息,可以使用 git config --list 命令:
$ git config --list
http.postbuffer=2M
user.name=runoob
user.email=test@runoob.com
有時(shí)候會(huì)看到重復(fù)的變量名使兔,那就說明它們來自不同的配置文件(比如 /etc/gitconfig 和 ~/.gitconfig)建钥,不過最終 Git 實(shí)際采用的是最后一個(gè)。
這些配置我們也可以在 ~/.gitconfig 或 /etc/gitconfig 看到虐沥,如下所示:
vim ~/.gitconfig
顯示內(nèi)容如下所示:
[http]
? ? postBuffer = 2M
[user]
? ? name = runoob
? ? email = test@runoob.com
也可以直接查閱某個(gè)環(huán)境變量的設(shè)定熊经,只要把特定的名字跟在后面即可,像這樣:
$ git config user.name
runoob
工作區(qū):就是你在電腦里能看到的目錄欲险。
暫存區(qū):英文叫stage, 或index镐依。一般存放在 ".git目錄下" 下的index文件(.git/index)中,所以我們把暫存區(qū)有時(shí)也叫作索引(index)天试。
版本庫:工作區(qū)有一個(gè)隱藏目錄.git槐壳,這個(gè)不算工作區(qū),而是Git的版本庫喜每。
下面這個(gè)圖展示了工作區(qū)务唐、版本庫中的暫存區(qū)和版本庫之間的關(guān)系
圖中左側(cè)為工作區(qū)雳攘,右側(cè)為版本庫。在版本庫中標(biāo)記為 "index" 的區(qū)域是暫存區(qū)(stage, index)枫笛,標(biāo)記為 "master" 的是 master 分支所代表的目錄樹吨灭。
圖中我們可以看出此時(shí) "HEAD" 實(shí)際是指向 master 分支的一個(gè)"游標(biāo)"。所以圖示的命令中出現(xiàn) HEAD 的地方可以用 master 來替換刑巧。
圖中的 objects 標(biāo)識(shí)的區(qū)域?yàn)?Git 的對象庫喧兄,實(shí)際位于 ".git/objects" 目錄下,里面包含了創(chuàng)建的各種對象及內(nèi)容啊楚。
當(dāng)對工作區(qū)修改(或新增)的文件執(zhí)行 "git add" 命令時(shí)吠冤,暫存區(qū)的目錄樹被更新,同時(shí)工作區(qū)修改(或新增)的文件內(nèi)容被寫入到對象庫中的一個(gè)新的對象中恭理,而該對象的ID被記錄在暫存區(qū)的文件索引中咨演。
當(dāng)執(zhí)行提交操作(git commit)時(shí),暫存區(qū)的目錄樹寫到版本庫(對象庫)中蚯斯,master 分支會(huì)做相應(yīng)的更新薄风。即 master 指向的目錄樹就是提交時(shí)暫存區(qū)的目錄樹。
當(dāng)執(zhí)行 "git reset HEAD" 命令時(shí)拍嵌,暫存區(qū)的目錄樹會(huì)被重寫遭赂,被 master 分支指向的目錄樹所替換,但是工作區(qū)不受影響横辆。
當(dāng)執(zhí)行 "git rm --cached <file>" 命令時(shí)撇他,會(huì)直接從暫存區(qū)刪除文件,工作區(qū)則不做出改變狈蚤。
當(dāng)執(zhí)行 "git checkout ." 或者 "git checkout -- <file>" 命令時(shí)困肩,會(huì)用暫存區(qū)全部或指定的文件替換工作區(qū)的文件。這個(gè)操作很危險(xiǎn)脆侮,會(huì)清除工作區(qū)中未添加到暫存區(qū)的改動(dòng)锌畸。
當(dāng)執(zhí)行 "git checkout HEAD ." 或者 "git checkout HEAD <file>" 命令時(shí),會(huì)用 HEAD 指向的 master 分支中的全部或者部分文件替換暫存區(qū)和以及工作區(qū)中的文件靖避。這個(gè)命令也是極具危險(xiǎn)性的潭枣,因?yàn)椴坏珪?huì)清除工作區(qū)中未提交的改動(dòng),也會(huì)清除暫存區(qū)中未提交的改動(dòng)幻捏。