到目前为止已经接触了四,五种版本控制系统了,但是个人觉得还是比较喜欢用CVS.尽管CVS有不少的缺陷的,尽管CVS的原作者已经有了新的替代版本SYN,但是我觉得到现在为止CVS的用户群依然不小. 尤其是Open Source的项目.
花了点时间,比较了一下各个版本控制系统的优点和缺点.
1.VSS(Visual Source Safe)
工作原理
lock-modify-unlock(有文件锁定机制)
优点
与微软公司自己的产品无缝结合,而且使用方便,操作简单
缺点
只能在Windows下运行,不能在Unix, Linux下运行。SourceSafe不支持异构环境下的配置管理,对用户而言是个麻烦事。这不是技术问题,是微软公司产品战略决定的。 适合于局域网内的用户群,并且使用人数比较少的时候比较适合.不适合于通过Internet连接的用户群,因为SourceSafe是通过“共享目录”方式存储文件的。
另外,VSS有文件锁定机制,这也决定了它不太适合用于比较大的项目,当开发人员比较多时,必定很多文件都被其它程序员锁定,确实回影响开发的进行.
说明
SourceSafe是Microsoft公司推出的配置管理工具 ,是Visual Studio的套件之一。 不过VSS不是微软的产品,是微软收购的产品, VSS最初的名字叫Source Safe,是一家小公司的产品,92年曾经获了最佳小型管理工具奖,然后立即被微软收购. SourceSafe的界面确实很难看。但是难看不碍事,确实简单比较容易使用. 新版本的VSS我确实没用过,我相信一定有不少的改进.
2.CVS(Concurrent Versions System)
工作原理
copy-modify-merge
优点
CVS支持并发的版本管理,与VSS不同的是,VSS有文件锁定机制,有就意味着在同一个时候着能够有一个程序员修改同一个文件.而CVS则没有这个限制。因此才会有后面的冲突的解决机制.
缺点
多个程序员修改一个文件的时候,可能回产生冲突,对于不能够自动合并的代码需要手工解决这些冲突,确实比较麻烦.另外在Linux下面安装和配置一个CVS服务器也不是一件简单的事情,每次都会花费我很长的时间.
管理和使用对初学者有一定难度,不易上手.
目录不受版本控制,不利于大规模项目的完整控制.
对于并发程度较高的模块,多人同时更新情况下,文件的合并操作不易完成.
只适合管理代码,不太适合管理文挡.
说明
普及程度就不用说了,用本山大叔的那句话,"地球人都知道".
CVS代表协作版本系统或者并发版本系统,是一种版本控制系统,方便软件的开发和使用者协同工作。
这是一个将一组文件放在层次目录树中以保持同步的系统。人们可以从 CVS 服务器上更新他们的本地层次树副本,并将修改的结果或新文件发回;或者删除旧文件。 CVS 基于客户端/服务器的行为使得其可容纳多用户,构成网络也很方便。这一特性使得 CVS 成为位于不同地点的人同时处理数据文件(特别是程序的源代码)时的首选。
典型配置(Windows平台)
CVSNT + TortoiseCVS
CVS确实比较复杂,但是那是在Linux下面,无论是配置还是使用都不容易入门.不过在Windows下面的使用比VSS还更简单方便,一样有GUI..强烈推荐TortoiseCVS做为CVS的客户端.另外WinCVS也不错。服务端在Windows下用CVSNT,也比较简单.
相关资源
CVS的相关资源可以说是多如牛毛,到出都是.另外,有本叫《版本控制之道》的书专门讲CVS的使用,翻了一下,确实没有什么帮助,确实很烂。下面是一些官方的website.
CVS HOME:http://www.cvshome.org
CVS NT http://www.cvsnt.com
WinCVS: http://www.wincvs.org
TortoiseCVS http://www.tortoisecvs.org/
3.SVN(Subversion)
没有具体研究过这个系统,只是大概用了一下.下面的资料来自其它地方.
说明
SubVersion相对于最常见的RCS,CVS,采用了更先进的分支管理系统,它的设计目标就是取代CVS,不过由于是一个比较新的系统,因此目前在开源中应用还不是非常常见,不过已经有不少的项目采用它作为版本控制系统了。
优于CVS之处
原子提交。一次提交不管是单个还是多个文件,都是作为一个整体提交的。在这当中发生的意外例如传输中断,不会引起数据库的不完整和数据损坏。
重命名/拷贝/删除文件这些动作都保存在版本历史纪录当中
对于二进制文件,使用了非常节省空间的方法保存(简单的理解,就是只保存和上一版本不同之处)
目录也是有版本历史的。整个目录树可以被移动或者拷贝,操作很简单,而且能够保留全部版本记录
分支的开销非常小
优化过的数据库访问,使得一些操作不必访问数据库就可以做到。这样减少了很多不必要的和数据库主机之间的网络流
GUI客户端
TortoiseSVN,基本上是从Tortoise那里继承过来的。也比较好用。
4.ClearCase
也没用过这个工具,资料仅供参考.
Rational公司的ClearCase是软件行业公认的功能最强大、价格最昂贵的配置管理软件。最早的ClearCase并不是rational的产品.也是收购其它公司的产品.
ClearCase主要应用于复杂产品的并行开发、发布和维护,其功能划分为四个范畴:版本控制、工作空间管理(Workspace Management)、构造管理(Build Management)、过程控制(Process Control)。ClearCase通过TCP/IP来连接客户端和服务器。另外,ClearCase拥有的浮动License可以跨越UNIX和 Windows NT平台被共享。
ClearCase的功能比CVS、SourceSafe强大得多,但是其用户量却远不如CVS、SourceSafe的多,主要原因是:ClearCase价格太昂贵.
5.HG(Mercurial)
Mercurial中文就是"水银"的意思,而在化学上"水银"写着hg,因此得名。
我现在正在使用的版本控制工具.和CVS有比较大的不同,CVS是2层的C/S模式,而hg是3层模式,任何人都可以维护一个hg才代码仓库.但是这样做有个缺点就是,每个人都要必须拥有一个代码仓库,所以网络上的数据传输量相当大,第一次pull代码的时候相当费时间.
优点
系统版本化,CVS里面是文件版本化,每一个文件都有一个修订版本号,实际上这比较分散,不容易管理,而在hg里面是很多个文件拥有一个版本号,一般来说是比较相关的改动.在hg里面这个叫ChangeSet.
其他
这个工具在国内很少人使用,所以中文资料匮乏.只有官方的website上有一些少得可怜的中文资料了.hg也有Windows版本的,但是只有命令行的,没有GUI.所以没有TortoiseSVN,TortoiseCVS那么好用了。
官方网站
http://www.selenic.com/mercurial/
其他的就是我只听说过名字,但从来都没有用过的了,不知道有没有人接触过,欢迎补充.
6.RCS
老古董,好象是比CVS还早的一个版本控制系统。
7.starteam
8.harvest