現(xiàn)在項(xiàng)目基本都采用git來(lái)進(jìn)行版本控制,最近比較好奇git的存儲(chǔ)機(jī)制到底是怎么樣的,研究了一下
簡(jiǎn)單介紹git最重要的算法(SHA-1)
- 通過(guò)git log查看草穆,會(huì)發(fā)現(xiàn)都會(huì)有一個(gè)40個(gè)字符組成的字符串,這個(gè)字符串是通過(guò)SHA-1算法計(jì)算出來(lái)的字符串
- SHA-1算法:兩個(gè)不同的內(nèi)容進(jìn)行計(jì)算出來(lái)的值(消息摘要)理論上來(lái)說(shuō)是不重復(fù)的(基于目前來(lái)說(shuō))
git的存儲(chǔ)機(jī)制詳解
先介紹下git的一個(gè)命令:git cat-file敢伸,查看消息摘要的詳細(xì)內(nèi)容;用的時(shí)候經(jīng)常會(huì)帶上 -p 參數(shù)
-
研究過(guò)程(基于我本地的一個(gè)版本庫(kù))
- 先通過(guò) git log 找到一個(gè)commitId悯姊,通過(guò) git cat-file 查看
git cat-file -p 71d8f2a8aecfc84b2a72814f525c76c128face53
tree b346468f50d856cc0a6089e4fe260b4f72c914e5 parent 5987828df851c3d93775e8a1eb49b8d709fd1fb5 author xx <xxx> 1489540261 +0800 committer xxx <xxx> 1489540267 +0800
- 從這里看出來(lái)一個(gè) commit 指向一個(gè) tree (一個(gè)tree管理一些tree和一些blob),接下來(lái)繼續(xù)看這個(gè)tree到底是什么
- 繼續(xù) git cat-file :
git cat-file -p b346468f50d856cc0a6089e4fe260b4f72c914e5
100644 blob e1b5186c600616e89692c94f64f4ed2e525fab23 .gitignore 100644 blob 2572cca5762d11828c4a296bcca7ded879f4929a LICENSE 100644 blob 7ba68141ca2199ab83d3160f700d0e4343298468 README.md 100644 blob ac8522fb58c89951af0089cb090a56f9856c05b0 a.txt 100644 blob 9b285c5c555323213ce7865e536d09e597268706 pom.xml 040000 tree 5165230a25966bca6377f32f80750b0640a9de02 src
- 上邊的結(jié)果有blob和tree:這個(gè)時(shí)候blob通常是一個(gè)文件贩毕,tree是一個(gè)目錄
- 那先來(lái)看看blob類型:
git cat-file -p e1b5186c600616e89692c94f64f4ed2e525fab23
悯许,這個(gè)時(shí)候看到的是一個(gè)文件的內(nèi)容:
為什么是這樣的呢,因?yàn)間it通過(guò)e1b5186c600616e89692c94f64f4ed2e525fab23指向了.gitignore文件辉阶,而這個(gè)文件的內(nèi)容被壓縮成另一個(gè)文件先壕,這些文件保存在項(xiàng)目的.git目錄下的objects目錄下,git的cat-file命令將blob還原成原有的文件內(nèi)容了睛藻。網(wǎng)上有壓縮的算法*.class target/ java-common-utils.iml .idea/
- 再來(lái)看看tree類型:
git cat-file -p 5165230a25966bca6377f32f80750b0640a9de02
可以看到還是兩個(gè)tree启上,可以一直cat-file下去知道沒(méi)有tree040000 tree 857c7710f03f0b9d33d3110273f525416ee310a6 main 040000 tree b63ccc7fa9ced1d7b84fd5de194a85fe66016bec test
- 那先來(lái)看看blob類型:
總結(jié)
- git對(duì)文件的比對(duì)是通過(guò)文件內(nèi)容的SHA-1消息摘要進(jìn)行對(duì)比是否有更改,所以速度會(huì)非车暧。快冈在;
- 先通過(guò) git log 找到一個(gè)commitId悯姊,通過(guò) git cat-file 查看