您好,欢迎访问三七文档
当前位置:首页 > 建筑/环境 > 工程监理 > CVS学习-安装与使用教程
2006年1月16日版本管理系统可以帮助开发人员有效地管理软件资源的版本问题。CVS(ConcurrentVersionSystem)是目前最常用的版本管理系统,而ECLIPSE是最流行的开放源码的集成开发环境。在ECLIPSE中,与CVS相关的功能被统称为小组开发环境。本系列的第1部分不仅解释了CVS的相关术语,还详细介绍了小组开发环境的建立过程;本系列的第2部分则试图以一种简明易懂的方式来讲解ECLIPSE小组开发环境的使用方法。1.前言版本管理系统可以帮助开发人员有效地管理软件资源(源代码文件、配置文件等)的版本问题。版本管理系统可以帮助开发人员追踪文件的修改履历;防止文件因疏忽而被错误的修改、删除;在小组开发环境中,帮助多个开发人员保持文件的同步;通过文件的修改履历,还可以帮助开发人员发现修改过程中产生的BUG,因此应用CVS可以在一定程度上提高软件的开发效率。现在很多开发工具中都集成了CVS功能,例如ECLIPSE、InteliJ、NetBeans等;虽然ECLIPSE等集成开发环境(IDE)对CVS提供了很好的支持,可以大幅降低CVS的使用难度,但是很多开发人员在使用CVS时还是不知所措。笔者认为这是由于他们不了解CVS的相关术语及CVS的工作模式所致。因此,本文首先介绍CVS的相关术语及CVS的工作模式。然后通过一些实例与应用场景,展示如何在ECLIPSE中使用小组开发环境。本文所使用的ECLIPSE没有安装本地语言包插件,操作界面为英文。但理解了相关术语后,读者即使在中文环境中也能正常操作。2.CVS的相关术语与CVS工作模式2.1术语解释修订版(revision):CVS版本管理系统用修订版来管理文件的修改履历,修订版用版本号来表示,即修订版号。对文件的每次修改(提交)都产生一个新的修订版。资源库(repository):资源文件的集合,版本管理的容器。在ECLIPSE中被称为CVS存储库。模块(module):资源文件的组织形式,在版本管理系统中的表现形式为目录(树形结构,可以嵌套)。输入(import):将处于资源库之外的软件模块登录到资源库。输出(export):从资源库中取出模块。使用export方式取出的模块拷贝不包含版本管理的相关信息,对该模块拷贝的修改也不能反映到资源库。工作拷贝(workingcopy):版本管理系统是一个典型的CLIENT/SERVER系统。用户对资源的修改不是直接在SERVER端进行的,而是根据资源库的内容创建一个本地的工作拷贝,用户在工作拷贝中工作,工作完成后再将修改的内容提交到资源库。签出(checkout):获得工作拷贝的操作。此前使用过VisualSourceSafe的读者需注意,在VisualSourceSafe中的checkout用于锁定文件。签入/提交(checkin/commit):将对工作拷贝的修改反映到资源库中的操作。在CVS中使用的术语是提交;在VisualSourceSafe中使用的术语是签入。更新(update):将资源库中的最新状态反映到工作拷贝的操作。冲突(conflict):在资源库同工作拷贝之间状态不一致的状态下进行签入或更新操作时,版本管理系统可能会尽量进行合并,如果版本管理系统不能完全处理上述不一致,就称之为产生了冲突。快照(snapshot):在某一时刻,模块中文件状态(包括文件内容及其版本管理元信息)的静态影像。标签(tag):由于CVS以文件为版本管理的基本单位,随着开发的进行,对不同的文件的修改次数是不一样的,各个文件的修订版号会因此而变得参差不齐。这不便于模块的管理。为此可以对某个时刻的快照赋予一个标识名称,标识名称就被称为标签。将来通过标签就可以获得模块在该时刻的快照。通过标签所获得的快照是静态的,不能被修改。在ECLIPSE中,标签与版本(Version)是同义词,一般都用于文件集合。需要指出的是:在很多中文资料里,修订版与版本往往不加区分,有时会将单个文件的修订版也称为版本。例如,A文件最新版本是1.3,这句话中的版本实际上指的是修订版。因此,需要根据上下文来确定版本的意义。分支(branch):分支是一种特殊的标签。从分支中签出的资源是可以被修改的。引入分支是为了更好地支持项目的并行开发过程。2.2工作模式为了解决因多人同时开发而可能产生的冲突问题,版本管理系统有两种常用的工作模式。模式一:锁定-修改-解锁模式在这种工作模式中,一个开发人员为了能够修改文件,首先必须锁定文件,锁定文件操作赋予了开发人员修改文件的权力。从一个文件被锁定后到其被解锁前,其他的开发人员不能再锁定该文件。这种工作模式适用于小规模的开发小组。如果采用这种工作模式,开发人员应尽量少、尽可能晚地锁定文件并尽可能早解锁文件。模式一是VisualSourceSafe的缺省工作模式。模式二:拷贝-修改-合并模式在这种工作模式中,每个开发人员都从资源库获得自己的工作拷贝,然后就可以自由的在工作拷贝中继续开发,开发完成后再向资源库提交自己的工作成果。如果在提交时产生了冲突,则必须在解决冲突后才能再提交。模式二比模式一具有更好的并发性,因而也适用于中、大规模的开发小组。模式二是CVS所采用的工作模式。锁定-修改-解锁模式是一种悲观的锁定模式,它假定在开发过程中可能会产生大量的冲突;而拷贝-修改-合并模式则比较乐观,它假定在开发过程中软件的设计及开发任务的分配都比较合理(软件的模块化程度高,开发人员一般各司其职),在开发过程中即使会产生冲突,但产生冲突的机率比较小。为了更好地使用CVS,我们在使用CVS时也应该遵循它的设计前提,努力提高软件的设计水平及项目管理的能力,否则将陷入疲于解决提交冲突的尴尬境地。如果想进一步了解CVS的理论知识,请参看文后的参考资料1和参考资料2。3.环境安装LINUX与WINDOWS是目前应用最普及的操作系统。下面首先介绍CVS服务器在两种操作系统上的安装与配置过程,然后介绍如何从ECLIPSE连接CVS服务器,最后介绍如何使用ECLIPSE共享模块。无论后台的CVS安装在何种操作系统之上,对于ECLIPSE来说,与CVS服务器建立了连接之后其使用方法是一样的。3.1在FEDORACORE3上安装、配置CVS3.1.1安装CVS本文所使用的LINUX发行版为FEDORACORE3。首先,查看在系统中是否已经安装了CVS服务器,如果没有安装,则可以从FEDORACORE3的发行光盘或从网络上下载相应的软件包,本文中使用的软件包为cvs-1.11.17-7.FC3.i386.rpm。安装过程如下(在本节中,绿色的为命令行,紧随命令行的黑色文本为系统响应):[root@emulatorcvsres]#rpm-ivhcvs-1.11.17-7.FC3.i386.rpmwarning:cvs-1.11.17-7.FC3.i386.rpm:V3DSAsignature:NOKEY,keyID4f2a6fd2Preparing...###########################################[100%]1:cvs###########################################[100%]可以用如下命令查询系统中是否已经安装了CVS服务器:[jiangch@emulator~]$rpm-qa|grepcvscvs-1.11.17-7.FC3确认在文件/etc/services中含有以下内容:cvspserver2401/tcp#CVSclient/serveroperations在目录/etc/xinetd.d中建立一个文件cvspserver,文件内容如下:servicecvspserver{socket_type=streamprotocol=tcpwait=nouser=rootpassenv=PATHserver=/usr/bin/cvsserver_args=--allow-root=/home/jiangch/cvsrepopserver-f}其中,--allow-root的值为CVS资源库的根目录。如果建立自己的CVS服务器,需要根据实际情况作相应的修改。3.1.2启动CVS服务在FEDORACORE中的CVS服务由xinetd管理,安装完成后通过下面的命令可以启动CVS服务:[root@emulatorcvsres]#/etc/init.d/xinetdrestartStoppingxinetd:[OK]Startingxinetd:[OK]3.1.3初始化资源库在LINUX中,可以用下面的命令初始化CVS资源库:[root@emulatorcvsres]#cvs-d/home/jiangch/cvsrepoinit3.1.4添加CVS用户初始化资源库后,会在CVS资源库的根目录下生成一个新的目录CVSROOT。在目录中新建一个名为passwd的文件,为了简便,文件内容的格式为:用户帐号:密码每个用户一行,用户帐号应在系统中存在。由于密码必须是加密的,可以从文件/etc/shadow中提取。这样CVS用户将与LIUNX系统用户具有相同的帐号和密码。3.1.5注意事项在缺省状态下LIUNX的安全性比较高,对目录、文件的读写操作有较严格的控制。为了在LINUX下方便的使用CVS,最好建立一个组(group),例如cvsusers,将CVS的用户都加入cvsusers中。这样一来,只要将CVS资源库根目录及其所有子目录(含目录中的所有文件)的读写权限赋予组cvsusers,组中的所有用户都能使用CVS。3.2在WINDOWSXP上安装、配置CVSNT本文以下的内容都基于WINDOWSXP+CVSNT+ECLIPSE。整个实验环境包括两台以WINDOWSXP2为操作系统的计算机,其中一台名为chjnb的计算机既作为CVS服务器又安装了ECLIPSE作为客户端,而另一台只安装了ECLIPSE。CVSNT与ECLIPSE都采用了本文写作时的最新版本,分别是CVSNT2.5.03.2151和ECLIPSE3.1.1。ECLIPSE3.1.1可以和CVSNT2.0.58b以上版本很好的协同工作(见参考资料3)。CVSNT最初起源于CVS,也是一个开放源码产品,具有跨平台的能力,可以运行在多种操作系统之上。WINDOWS版的CVSNT在安装和使用上都比较方便,对WINDOWS用户而言具有很强的亲和力。WINDOWS版的CVSNT经过多年的发展,其功能与稳定性得到不断的加强,完全可以胜任实际工作中的版本管理任务。而且相对于CVS而言,CVSNT还扩展了不少功能。CVSNT与CVS的比较请参看参考资料4。3.2.1安装CVSNTCVSNT可以从以下地址获得。在WINDOWS系统上CVSNT有安装程序cvsnt-2.5.03.2151.msi(随版本的不同文件名也不同)。一般采取缺省安装方式安装后,CVSNT即可正常工作,如果想控制安装过程,则可以选择定制安装方式。例如在图1、图2中修改了安装目录。图1:选择CVSNT的安装类型图2:修改CVSNT的安装目录,选择CVSNT的可安装组件安装完成后可以通过菜单操作【开始】→【CVSNT】→【CVSNTControlPanel】或控制面板打开CVSNT的控制管理台。为了使用CVSNT进行版本管理,首先必须建立一个资源库。在CVSNT的控制管理台中选择ConfigurationRepository面板并单击Add,出现如图3所示的画面。图3:初始化资源库在Location中填入资源库的位置,在Description中填写该资源库的说明信息(可以为空)。值得注意的是当Location包含多级目录时,Name输入框中的缺省值不对,需要修改,例如可以使用最后一级目录名,如图3。最后点击OK按钮,在随后出现的询问是否初始化资源库的确认对话框中选择Yes即可。3.2.2Windows防火墙如果在安
本文标题:CVS学习-安装与使用教程
链接地址:https://www.777doc.com/doc-2907271 .html