Git簡介

什么是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)系


三者之間的關(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)幻捏。


?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末盆犁,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子篡九,更是在濱河造成了極大的恐慌谐岁,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異伊佃,居然都是意外死亡窜司,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進(jìn)店門锭魔,熙熙樓的掌柜王于貴愁眉苦臉地迎上來例证,“玉大人路呜,你說我怎么就攤上這事迷捧。” “怎么了胀葱?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵漠秋,是天一觀的道長。 經(jīng)常有香客問我抵屿,道長庆锦,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任轧葛,我火速辦了婚禮搂抒,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘尿扯。我一直安慰自己求晶,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布衷笋。 她就那樣靜靜地躺著芳杏,像睡著了一般。 火紅的嫁衣襯著肌膚如雪辟宗。 梳的紋絲不亂的頭發(fā)上爵赵,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天,我揣著相機(jī)與錄音泊脐,去河邊找鬼空幻。 笑死,一個(gè)胖子當(dāng)著我的面吹牛容客,可吹牛的內(nèi)容都是我干的氛悬。 我是一名探鬼主播,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼耘柱,長吁一口氣:“原來是場噩夢啊……” “哼如捅!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起调煎,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤镜遣,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體悲关,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡谎僻,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了寓辱。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片艘绍。...
    茶點(diǎn)故事閱讀 38,577評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖秫筏,靈堂內(nèi)的尸體忽然破棺而出诱鞠,到底是詐尸還是另有隱情,我是刑警寧澤这敬,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布航夺,位于F島的核電站,受9級特大地震影響崔涂,放射性物質(zhì)發(fā)生泄漏阳掐。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一冷蚂、第九天 我趴在偏房一處隱蔽的房頂上張望缭保。 院中可真熱鬧,春花似錦蝙茶、人聲如沸艺骂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽彻亲。三九已至,卻和暖如春吮廉,著一層夾襖步出監(jiān)牢的瞬間苞尝,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工宦芦, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留宙址,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓调卑,卻偏偏與公主長得像抡砂,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子恬涧,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,452評論 2 348

推薦閱讀更多精彩內(nèi)容