科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道应用软件版本控制系统小调查

版本控制系统小调查

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

到目前为止已经接触了四,五种版本控制系统了,但是个人觉得还是比较喜欢用CVS.尽管CVS有不少的缺陷的,尽管CVS的原作者已经有了新的替代版本SYN,但是我觉得到现在为止CVS的用户群依然不小.

作者:水手 来源:CSDN 2008年3月24日

关键字: 控制 系统 项目管理 版本

  • 评论
  • 分享微博
  • 分享邮件

在本页阅读全文(共19页)

到目前为止已经接触了四,五种版本控制系统了,但是个人觉得还是比较喜欢用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

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章