•项目开发靠的是一个团队的能力,很少有大中型项目是由个人完成的。对于团队开发来讲---能控制每个人的分工和权限,可以让多个人同时编辑同一份代码,并由程序来提醒两次修改中存在的冲突,可以查看某一处改动是谁做的---类似这样的需求就显得尤为重要。这也是学习CVS的缘由,它可以很好的解决上述问题。
•CVS是一个著名的版本控制工具
•CVS的英文全称是Concurrent Version System(并行版本系统)。它主要用于记录源文件的历史。CVS是使用“客户端/服务器”(Client/Server)模式来工作的,这也是优秀版本控制系统的发展趋势。
•因为CVS采用C/S体系,所以代码、文档的各种版本都存储在服务器端,开发者首先从服务器上获得相关文件到本地计算机,然后在此基础上进行开发。开发者可以随时将新代码提交给服务器,也可以通过更新操作获得最新的代码,从而与其他开发者保存一致。
–Repository(仓库) :CVS仓库存储全部的版本控制下的文件拷贝,通常不允许直接访问,只能通过CVS命令,获得一份本地拷贝,改动后在提交会仓库。而仓库通常是与工作目录分离的。CVS可以通过多种方式访问仓库,每种方式有不同的目录表示形式。
–Revision(修订版) :每一个文件的各个Revision都不相同,形如1.1, 1.2等,一般1.1是该文件的第一个Revision,后面的一个将自动增加最右边的一个整数,如1.2,1.3, 1.4 等。Revision总是偶数个数字。一般情况下Revision看作是CVS自己内部的一个编号,而Tag则可以标志用户的特定信息。
–Tag(标签) :用符号化得表示方法标志文件特定Revision信息。通常不需要对某个孤立的文件做Tag,而是对所有的文件同时做一个Tag,以后用户可以仅向特定Tag的文件提交或者检出。
–Branch(分支) :分支是开发团队用来共享正在进行中的工作的地方。任何时候,团队成员都可以使用一个分支的内容作为新工作的基础。每个 CVS 资源库都至少有一个分支,称为 HEAD。HEAD代表CVS里的主流分支。
–Module(模块) :CVS服务器根目录下的第一级子目录。通常用于存放一个项目的所有文件。
–Check out(检出) :通常指将仓库中的整个模块首次导出到本地。
–Check in(导入) :通常指提交整个目录结构并创建一个新模块。
–Release(发行版本) :整个产品的版本。
–Update(更新) :从模块中下载其他人修改过的文件,更新本地的拷贝。
–Commit(提交) :将自己修改过的文件提交到模块中。