标签:
前面一篇文章介绍了本地仓库的一系列操作,下面我们将进一步了解Git的工作原理,介绍Git对象模型。
刚开始使用Git的时候,对Git对象模型、工作原理并不理解,但是经过一段时间的使用、熟悉之后,然后再来理解这些内容就比较容易了。
下面开始介绍Git对象,然后通过一个实例展示Git对象模型。
在Git系统中有四种类型的对象,所有的Git操作都是基于这四种类型的对象。
上面我们介绍了Git对象,在Git系统中,每个Git对象都有一个特殊的ID来代表这个对象,这个特殊的ID就是我们所说的SHA1哈希值。
SHA1哈希值是通过SHA1算法(SHA算法家族的一种)计算出来的哈希值,对于内容不同的对象,会有不同的SHA1哈希值。如果你读过前面一篇文章,就肯定还记得我们是怎么根据commit id撤销更新的,这里的commit id就是一个SHA1哈希值。
下面我们通过一个例子来认识一下上面的四种对象,为了更加清楚,这里将一步步展示经过一系列操作后对象的关系变化。
通过"git log --pretty=raw"可以得到每个commit的SHA1哈希值,也可以得到这个commit对应的tree的哈希值。
所以,一个commit对象一般包含以下信息:
在Git对象模型的研究中,有一个很有用的命令"git cat-file",可以通过这个命令查询特定对象的信息:
下面我们看一下在这次提交中commit、tree对象的类型和内容。这里可以看到,在这一次的commit中tree对象的内容指向一个blob对象。
同样,我们可以查看blob对象的类型和内容,这里可以看到blob的内容就是我们要提交的文件的内容。
所以,根据上面的一些数据,我们可以看到在这一次的提交中产生了三个对象,同时看到了commit、tree、blob三个对象的关系如下:
继续使用"git log --pretty=raw"查看commit log。
同样通过"git cat-file"我们可以看到每一个对象的类型和内容,这里就不一步一步上图了,直接给出所有的对象关系。
这里需要注意的一点,Perforce、SVN和CVS属于"增量文件系统" (Delta Storage systems),它们每次只存储提交(commit)之间的差异。而对于Git,它会把你的每次提交的文件的全部内容(snapshot)都会记录下来。
$ git log --pretty=raw commit 4ea6c317a67e73b0befcb83c36b915c1481f2efe tree 2735b08cab34af7732970fec95a1b3e718628d53 parent c2163e267380f71373f29f922e7089abbb741772 author WilberTian <Wilber***.com> 1419771391 +0800 committer WilberTian <Wilber***.com> 1419771391 +0800 add app.py, __init__.py and calc.py
同样的方式,我们可以得到一张更复杂的对象关系图:
Git对象模型就像是Git系统特有的文件系统,以特定的方式存储更新的内容、元数据以及版本历史信息。
通过Git对象模型进一步熟悉了Git的工作原理,相信有了这些知识,我们就可以分析git命令背后到底发生了什么。
Git Step by Step – (3) Git对象模型
标签:
原文地址:http://www.cnblogs.com/wilber2013/p/4192478.html