团队和版本管理.ppt
第5章 团队和版本管理,现在软件项目开发中,应用最广的两个团队协作和版本管理工具是CVS和SVN。CVS历史较长,应用更广一些,大量开源软件使用CVS共享源代码,与全球的贡献者一起协作开发。SVN则是近几年兴起的另外一套版本管理工具,功能和CVS类似,但有更多的新特征。Eclipse已经内建有CVS的支持,SVN则要通过安装新的插件来实现。sCVS已经开始逐渐被SVN取代,新的软件项目已经纷纷开始采用SVN。本章将学习SVN服务器的搭建,安装Eclipse的SVN客户端插件Subclipse,以及Subclipse的使用。,5.1 版本控制的基本概念,在本章的开始,先了解一下版本控制的概念,并认识一下现在流行的版本控制软件SVN。学习SVN的工作原理,其中重点是了解SVN如何进行版本控制,多人同时进行一个项目开发的时候,是如何利用SVN来进行协作的。,5.1.1 什么叫版本控制系统?,大家都知道软件都是有版本编号的,不过软件开发过程中的版本控制不代表软件发行时的版本。软件开发过程中的版本控制就是记录源代码修改的过程,形成历史记录。开发者可以利用版本管理系统把源代码还原到任何一次历史记录。例如在开发过程中,不小心写了一个Bug,这个Bug在代码做了多次修改后才发现,利用版本控制系统就可以查找出到底哪一次修改出现了这个Bug。,5.1.2 什么是SVN,SVN 的全称是Subversion。Subversion的系统内有一个主要命令是svn,所以SVN也成了Subversion的缩写。在 Subversion之前,CVS已经使用了很多年。尽管CVS的广泛应用,让其成为了一种事实上的标准,但是CVS还是存在着不少缺点。Subversion的出现就是为了解决CVS的缺点。Subversion也是近两年才得以广泛应用,然后迅速普及。,5.1.3 SVN的基本原理,SVN的基本结构其实很简单,在SVN服务器端,建立有版本库(Repository),用户(程序员、参与开发者)利用SVN客户端软件,通过网络连接SVN服务器,读取或者修改版本库中的文件;SVN服务器记录下这些文件的每一次修改。,5.1.4 SVN的拷贝-修改-合并方案,大家都试过使用共享文件夹的方式,在网络上和其他人一起共同编辑某个文档。某些软件,例如Word,采用锁定的机制,避免共享者之间产生冲突。但是,如果有一方一直锁定着这个文件,那么另一方就无法修改编辑这个文件了。SVN和CVS等等版本控制系统采取一种称为“拷贝-修改-合并”的方案,让写作者可以同时编辑修改同一份代码。,5.2 搭建SVN服务器,现在网络上很多开源软件社区都已经应用SVN取代CVS作为主要的版本控制系统了。像S、tigris.org、Google Code等等都提供了SVN服务。前提是,必须在这些社区注册软件项目,然后才能使用它们提供的SVN服务。如果只是自己做开发,或者商业开发,需要一个内部的SVN系统,那就要自己搭建SVN服务器了。在Subversion的官方网站上提供了详细的文档,介绍了如何搭建一个SVN服务器。另外还有不少第三方的软件,可以帮助用户更快捷地搭建、管理SVN服务器。下面介绍的VisualSVN就是这样一个软件。,5.2.1 安装VisualSVN,通过访问VisualSVN的官方网站http:/或者直接输入下面的地址http:/server/download/就可以获得VisualSVN Server。,5.2.2 建立版本库,VisualSVN的功能其实很简单,仅仅实现两SVN的一些基本管理功能,但是这些功能却是最常用的。大多数用户并不会完全使用SVN的所有功能,最常用的管理任务就是建立版本资源库,管理用户,对版本资源库的文件夹进行管理。先看一下如何建立新的资源库。,5.2.2 建立版本库,5.2.3 建立用户,SVN最重要的作用是解决多个用户间开发协同问题,一个SVN资源库必然是要容许多个用户访问的。当然,也不排除只有一个用户的情况,单用户的情况就是个人把SVN当作一个开发的历史记录,而不是协同工具。,5.3 安装Subclipse,在 Eclipse平台以及JDT的发行包里面,还没有直接包含SVN的支持。Eclipse.org内已经有一个SVN的插件项目,只是目前这个插件项目还不是很完善,安装起来比较麻烦。可喜的是还有其他很多第三方的SVN插件,Subclipse就是其中一个。Subclipse安装简单,功能也比较完善。Subclipse的官方网站是http:/。建议使用Eclipse的安装和更新功能进行安装。,5.3 安装Subclipse,5.4 Eclipse中使用SVN,安装了Subclipse后,就可以在Eclipse中使用SVN了。下面将演示在Eclipse中使用SVN。在这个演示中将先学习如何使用Subclipse连接SVN服务器。然后把上一章建立的项目HelloPDE发布的到SVN上,然后模拟多人同时对同一段代码进行修改,学习如何使用Subclipse和SVN进行协同开发,并解决协同开发过程中的冲突。,5.4.1 建立版本仓库的连接,首先打开HelloPDE项目。使用SVN服务器的第一步是建立SVN版本仓库的连接。,5.4.2 文件的同步标志,如何才能知道哪些文件需要和服务器同步呢?在项目浏览视图或者包视图中,每个文件图标的右下角都有一个同步标志。,5.4.3 发送修改到服务器,在前面建立的了项目的SVN连接后,只是在服务器建立了项目的文件夹而已,项目中所有文件都还没有发送到服务器。正如Synchronize视图中所示,所有文件都附带了新增的同步标志。这时候,按视图工具栏上的发送按钮。,5.4.4 获取SVN服务上的新版本,要检查SVN服务器上的文件有没有被修改,或者说是否有新的版本,在项目上点击鼠标右键,选择弹出菜单的Team-Synchronize with Repository。如果SVN服务器上没有更新,则会弹出没有更新的提示框。,5.4.5 解决冲突,一个团队中,多人同时开发一个项目或者一个源代码的时候,出现冲突是难免的。这种情况就是前面图5-2中第4步出现的冲突问题。SVN会发现冲突,Subclipse也提供了比较源代码的工具。如何解决冲突,就要有开发者自己作决定了。,5.4.5 解决冲突,5.4.6 从SVN服务器导入新的项目,很多时候,软件项目并不是自己创建。可能是团队中其他人创建,也可能是网上的一个开源项目。只要这些项目共享到某个SVN服务器中,就可以把它们导入到Eclipse中,并建立成为一个新的项目。下面以本书例子程序的项目为例,说明如何从SVN服务器导入新的项目。为了方便大家获得本书的源代码,特别建立了一个项目网站,网址是:http:/源代码的SVN服务器地址是:http:/,5.5 小结,本章认识了版本管理工具SVN,了解了版本管理的一些基本知识。版本管理工具并不是如名称所说的那样,只是管理软件的“版本”。实际上版本管理工具是一种团队协作工具。流行的版本管理工具有SVN和CVS。CVS历史比较悠久,使用非常广泛,但也存在不少的缺陷,已经开始逐渐被SVN所取代。要使用SVN进行团队协作,首先要建立SVN服务器。VisualSVN是Windows中管理SVN服务器的软件。可以快速地建立SVN服务器,也可以对SVN服务器进行简单的管理。包括建立版本仓库、管理用户。Eclipse本身是没有包含SVN功能的,所以要安装支持SVN的插件。目前比较完善的一个SVN插件是Subclipse。可以通过Eclipse的在线安装功能安装Subclipse插件。,