git和svn實(shí)現(xiàn)的原理是不一樣的;git是分布式的版本控制系統(tǒng),svn不是,這是git和svn非分布式的版本控制系統(tǒng)最核心的區(qū)別,git把內(nèi)容按元數(shù)據(jù)方式存儲(chǔ),而svn是按文件方式存儲(chǔ)。
本文操作環(huán)境:Windows10系統(tǒng)、Git2.30.0版、Dell G3電腦。
git和svn實(shí)現(xiàn)的原理一樣嗎
Git是一個(gè)開(kāi)源的分布式版本控制系統(tǒng),用于敏捷高效地處理任何或小或大的項(xiàng)目。
?Git 是 Linus Torvalds 為了幫助管理 Linux 內(nèi)核開(kāi)發(fā)而開(kāi)發(fā)的一個(gè)開(kāi)放源碼的版本控制軟件。
?Git 與常用的版本控制工具 CVS, Subversion 等不同,它采用了分布式版本庫(kù)的方式,不必服務(wù)器端軟件支持。
?一、Git 與 SVN 區(qū)別
?GIT不僅僅是個(gè)版本控制系統(tǒng),它也是個(gè)內(nèi)容管理系統(tǒng)(CMS),工作管理系統(tǒng)等。
?如果你是一個(gè)具有使用SVN背景的人,你需要做一定的思想轉(zhuǎn)換,來(lái)適應(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)不特別,就是版本庫(kù)中的另外的一個(gè)目錄。
-
4、GIT沒(méi)有一個(gè)全局的版本號(hào),而SVN有:目前為止這是跟SVN相比GIT缺少的最大的一個(gè)特征。
-
5、GIT的內(nèi)容完整性要優(yōu)于SVN:GIT的內(nèi)容存儲(chǔ)使用的是SHA-1哈希算法。這能確保代碼內(nèi)容的完整性,確保在遇到磁盤(pán)故障和網(wǎng)絡(luò)問(wèn)題時(shí)降低對(duì)版本庫(kù)的破壞。
?二、Git原理:Git 工作區(qū)、暫存區(qū)和版本庫(kù)
?基本概念
?我們先來(lái)理解下Git 工作區(qū)、暫存區(qū)和版本庫(kù)概念
工作區(qū):就是你在電腦里能看到的目錄。
暫存區(qū):英文叫stage, 或index。一般存放在 “.git目錄下” 下的index文件(.git/index)中,所以我們把暫存區(qū)有時(shí)也叫作索引(index)。
版本庫(kù):工作區(qū)有一個(gè)隱藏目錄.git,這個(gè)不算工作區(qū),而是Git的版本庫(kù)。
?下面這個(gè)圖展示了工作區(qū)、版本庫(kù)中的暫存區(qū)和版本庫(kù)之間的關(guān)系:
?圖中左側(cè)為工作區(qū),右側(cè)為版本庫(kù)。在版本庫(kù)中標(biāo)記為 “index” 的區(qū)域是暫存區(qū)(stage, index),標(biāo)記為 “master” 的是 master 分支所代表的目錄樹(shù)。
?圖中我們可以看出此時(shí) “HEAD” 實(shí)際是指向 master 分支的一個(gè)”游標(biāo)”。所以圖示的命令中出現(xiàn) HEAD 的地方可以用 master 來(lái)替換。
?圖中的 objects 標(biāo)識(shí)的區(qū)域?yàn)?Git 的對(duì)象庫(kù),實(shí)際位于 “.git/objects” 目錄下,里面包含了創(chuàng)建的各種對(duì)象及內(nèi)容。
?當(dāng)對(duì)工作區(qū)修改(或新增)的文件執(zhí)行 “git add” 命令時(shí),暫存區(qū)的目錄樹(shù)被更新,同時(shí)工作區(qū)修改(或新增)的文件內(nèi)容被寫(xiě)入到對(duì)象庫(kù)中的一個(gè)新的對(duì)象中,而該對(duì)象的ID被記錄在暫存區(qū)的文件索引中。
?當(dāng)執(zhí)行提交操作(git commit)時(shí),暫存區(qū)的目錄樹(shù)寫(xiě)到版本庫(kù)(對(duì)象庫(kù))中,master 分支會(huì)做相應(yīng)的更新。即 master 指向的目錄樹(shù)就是提交時(shí)暫存區(qū)的目錄樹(shù)。
?當(dāng)執(zhí)行 “git reset HEAD” 命令時(shí),暫存區(qū)的目錄樹(shù)會(huì)被重寫(xiě),被 master 分支指向的目錄樹(shù)所替換,但是工作區(qū)不受影響。
?當(dāng)執(zhí)行 “git rm –cached
?當(dāng)執(zhí)行 “git checkout .” 或者 “git checkout —
?當(dāng)執(zhí)行 “git checkout HEAD .” 或者 “git checkout HEAD
推薦學(xué)習(xí):《Git教程》