yang3wei的专栏

Enjoy my life!

Git 与 SVN 之间的五个基本区别

| Comments

原文链接:
http://blog.csdn.net/dadoneo/article/details/6098540
在比较两者之前,可以阅读:
SVN + GIT = 鱼与熊掌兼得
开源版本控制 SVN 用户严重的 git
如何在 SVN 系统中使用 git

如果你在读这篇文章,说明你跟大多数开发者一样对 GIT 感兴趣,
如果你还没有机会来试一试 GIT,我想现在你就要了解它了。

GIT 不仅仅是个版本控制系统,它也是个内容管理系统(CMS),工作管理系统等。
如果你是一个具有使用 SVN 背景的人,
你需要做一定的思想转换,来适应 GIT 提供的一些概念和特征。
所以,这篇文章的主要目的就是通过介绍 GIT 能做什么、
它和 SVN 在深层次上究竟有什么不同来帮助你认识它。

那好,这就开始吧…

1.GIT 是分布式的,SVN 不是:

这是 GIT 和其它非分布式的版本控制系统,例如SVN,CVS等,最核心的区别。
如果你能理解这个概念,那么你就已经上手一半了。
需要做一点声明,GIT 并不是目前第一个或唯一的分布式版本控制系统。
还有一些系统,例如 Bitkeeper, Mercurial 等,也是运行在分布式模式上的。
但 GIT 在这方面做的更好,而且有更多强大的功能特征。

GIT 跟 SVN 一样有自己的集中式版本库或服务器。
但,GIT 更倾向于被使用于分布式模式,也就是每个开发人员从中心
版本库/服务器上 chect out 代码后会在自己的机器上克隆一个自己的版本库。
可以这样说,如果你被困在一个不能连接网络的地方时,就像在飞机上,地下室,
电梯里等,你仍然能够提 交文件,查看历史版本记录,创建项目分支,等。
对一些人来说,这好像没多大用处,但当你突然遇到没有网络的环境时,这个将解决你的大麻烦。

同样,这种分布式的操作模式对于开源软件社区的开发来说也是个巨大的恩赐,你不必再像以前那样做出补丁包,
通过 email 方式发送出去,你只需要创建一个分支,向项目团队发送一个推请求。
这能让你的代码保持最新,而且不会在传输过程中丢失。GitHub.com 就是一个这样的优秀案例。

有些谣言传出来说 Subversion 将来的版本也会基于分布式模式。但至少目前还看不出来。

2.GIT 把内容按元数据方式存储,而 SVN 是按文件:

所有的资源控制系统都是把文件的元信息隐藏在一个类似 .svn.cvs 等的文件夹里。
如果你把 .git 目录的体积大小跟 .svn 比较,你会发现它们差距很大。
因为,.git 目录是处于你的机器上的一个克隆版的版本库,
它拥有中心版本库上所有的东西,例如标签,分支,版本记录等。

3.GIT 分支和 SVN 的分支不同:

分支在 SVN 中一点不特别,就是版本库中的另外的一个目录。如果你想知道是否合并了一个分支,
你需要手工运行像这样的命令 svn propget svn:mergeinfo,来确认代码是否被合并。
感谢 Ben 同学指出这个特征。所以,经常会发生有些分支被遗漏的情况。
然而,处理 GIT 的分支却是相当的简单和有趣。你可以从同一个工作目录下快速的在几个分支间切换。
你很容易发现未被合并的分支,你能简单而快捷的合并这些文件。

4.GIT 没有一个全局的版本号,而 SVN 有:

目前为止这是跟 SVN 相比 GIT 缺少的最大的一个特征。
你也知道,SVN 的版本号实际是任何一个相应时间的源代码快照。
我认为它是从 CVS 进化到 SVN 的最大的一个突破。
因为 GIT 和 SVN 从概念上就不同,我不知道 GIT 里是什么特征与之对应。
如果你有任何的线索,请在评论里奉献出来与大家共享。
更新:有些读者指出,我们可以使用 GIT 的 SHA-1 来唯一的标识一个代码快照。
这个并不能完全的代替 SVN 里容易阅读的数字版本号。但,用途应该是相同的。

5.GIT 的内容完整性要优于 SVN:

GIT 的内容存储使用的是 SHA-1 哈希算法。
这能确保代码内容的完整性,确保在遇到磁盘故障和网络问题时降低对版本库的破坏。
这里有一个很好的关于 GIT 内容完整性的讨论 –
http://stackoverflow.com/questions/964331/git-file-integrity

GIT 和 SVN 之间只有这五处不同吗?

当然不是。我想这五个只是 “最基本的” 和 “最吸引人” 的,我只想到这五点。
如果你发现有比这五点更有趣的,请共享出来,欢迎。

Comments