使用SVN进行版本控制.ppt

上传人:小飞机 文档编号:4914992 上传时间:2023-05-23 格式:PPT 页数:75 大小:2.35MB
返回 下载 相关 举报
使用SVN进行版本控制.ppt_第1页
第1页 / 共75页
使用SVN进行版本控制.ppt_第2页
第2页 / 共75页
使用SVN进行版本控制.ppt_第3页
第3页 / 共75页
使用SVN进行版本控制.ppt_第4页
第4页 / 共75页
使用SVN进行版本控制.ppt_第5页
第5页 / 共75页
点击查看更多>>
资源描述

《使用SVN进行版本控制.ppt》由会员分享,可在线阅读,更多相关《使用SVN进行版本控制.ppt(75页珍藏版)》请在三一办公上搜索。

1、使用SVN进行版本控制,李 洋,摘 要,一、Subversion简介二、版本控制的基本知识三、Subversion常用功能四、客户端工具TortoiseSVN五、SVN使用中常见问题,一、Subversion简介,版本控制是管理信息变更的一门艺术版本控制工具早已经成为许多程序员的主要工具之一 版本控制软件的用途并不仅限于软件开发的领域,只要人们使用计算机来管理经常变更的信息,就需要使用版本控制工具 协同工作,大大提高团队工作效率及时了解团队中其他成员的进度资料共享记录每个文件从诞生到最终完成全过程的每步细节,什么是Subversion?,Subversion 是一个自由的、开放源码的版本控制系

2、统 它可以管理各个时刻的文件和目录Subversion 将文件存放在repository库中。这个仓库非常类似于一个普通的文件服务器,只是它还可以记录文件和目录曾经做过的每一次变更Subversion允许你数据恢复到早期版本,或者是检查数据修改的历史,可把版本控制系统比作一种“时间机器”,什么是Subversion?,Subversion的仓库可以通过网络来访问,允许不同的用户在不同的计算机上使用。不同的使用者可以进行协同工作。而且所有工作都是有记录的,如果有错只要撤销就可以。Subversion只是版本控制系统,不是软件配置管理系统(SCM)。它是一个通用系统,可以管理任何类型的文件集它是一

3、个通道,可以管理任何计算机中的文件系统。,Subversion的历史,CVS有明显的局限性和功能上的不足。2000年开始,CollabNet公司 就开始着手开发新的版本控制系统来代替CVS。Karl Fogel 和Jim Blandy 是CVS开发者,加入到开发subversion当中。他们让 Subversion 来使用 CVS 的特性,并且保留相同的开发模型,但是避开 CVS 的那些明显的缺陷。Subversion 于2001年8月进入“自测”阶段。,Subversion的特色,目录控制 CVS 只能跟踪单个文件的历史,而 Subversion 实现了一个虚拟的受控文件系统,可以跟踪整个目

4、录的变更。真正的版本历史由于 CVS 只限于记录文件的版本信息,像文件复制、重命名这样的操作它就不支持,在 Subversion 中我们可以添加、删除、复制和重命名文件和目录。,Subversion的特色,原子化提交一个变更集要么完整地被提交到仓库中,要么不做任何改变,从而避免发生不完整地提交变更的情况。受控元数据 每一个文件和目录都有一个与其对应的属性集。可选的网络层 Subversion 仓库的存取是一个抽象概念,有利于其他人实现新的网络访问机制,Subversion 可以作为一个外部模块插入到 Apache HTTP 服务器中。,Subversion的特色,一致的数据处理 Subvers

5、ion 使用一种二进制的比较算法来表示文件之间的区别。高效的分支和标记 分支和标记所带来的开销与项目的规模并没有直接的关系,Subversion 在创建分支和标记时使用类似“连接”的方式来复制项目。扩展能力它是由一组设计良好的 APIs实现的,包含在 C 的共享库中,这使得它很容易维护。也很容易被其他应用程序或语言使用,Subversion的体系结构,Subversion的体系结构,典型的client/server模式结构在系统的一端是存放着所有受控制数据的 Subversion 仓库。另一端是 Subversion 的客户端程序,管理着受控数据的一部分在本地的映射(称为“工作副本”)。在这两

6、端之间,是通过各种仓库存取层(Repository Access,RA)的多条通道。这些通道中,有些要使用计算机网络,再通过用来访问 Subversion 仓库的服务器。而有些则完全绕过了网络,直接对仓库进行操作。,Subversion的组件,Svn一个命令行的客户端程序Svnversion报告本地工作副本状态(当前档案的修订版本号表示)的程序Svnadmin 用来创建或者是修复仓库的工具 svndumpfilter 过滤资源库程序,Subversion的组件,mod_dav_svn Apache 服务器的一个插件模块,用来使其他人可以通过网络访问这个仓库 svnserve 一个定制的、独立的

7、 Subversion 服务程序。可作为一个驻留进程运行或者是由 SSH 调用。是使仓库可以被别人通过网络访问的另一种方法 常用的组件是svn和svnadmin,有图形化客户端来实现svn和svnadmin功能。,访问资源库的几种方式,样式 存取方式file:/直接从本地磁盘上访问仓库http:/通过 WebDAV 协议访问 Apache 服务器而访问仓库https:/和 http:/相同,但使用 SSL 来作加密svn:/通过svnserve服务自定义的协议svn+ssh:/和 svn:/相同,但通过SSH封装,资源库的URL解析,所有被Subversion管理的目录、文件有唯一路径支持的协

8、议有http,https,svn,svns,filehttp:/svn/kexie/proj/account/trunk/,protocol,host,repository,directory,SVN服务器端数据目录,dav目录:提供给Apache与mod_dav_svn使用的目录,存储内部数据db目录:所有版本控制的数据存放文件hooks目录:放置hook脚本文件的目录locks目录:用来放置Subversion文件库锁定数据的目录,用来追踪存取文件库的客户端 format文件:一个文本文件,记录文件库配置的版本号 conf目录:是这个仓库的配置文件(仓库的用户访问帐号、权限等),二、版本控

9、制的基本知识,仓库(The Repository)版本控制模型实际工作中的subversionsubversion/cvs/vss比较,仓库(The Repository),Subversion 是一个集中式的系统。它的核心是一个用来存放数据的中心仓库。中心仓库使用典型的文件和目录层次结构树状结构来存储信息。许许多多的客户端可以连接到中心仓库,然后读取或者写入文件。客户端通过写文件来使其他人共享,也可以读取其它客户端所写入的文件。典型的客户端/服务器系统模型,如图所示:,仓库(The Repository),仓库(The Repository),仓库就是一种文件服务器,只是不是通常的那种。Su

10、bversion 仓库可以记录写入仓库的每一次更改。这些更改包括对每一个文件的每一次修改,甚至是对目录本身的修改,例如添加文件、删除文件和对文件和目录的重新编排。这些特性使得 Subversion 仓库与一般的文件服务器相比较为特殊。客户端同样可以读取文件和目录以前某个时刻的状态。版本控制系统的核心:记录和跟踪数据的修改历史,版本控制模型,版本控制系统的核心任务是使得数据可以协作处理和共享。但是不同的系统使用不同的策略来达到这个目标。文件共享的问题:怎样让系统允许用户共享信息,而不会让他们因意外而互相干扰?锁定修改解锁方案 复制修改合并方案,锁定修改解锁方案,许多版本控制系统都使用“锁定修改解

11、锁”模型来解决这个问题,诸如:VSS在这样一个系统中,仓库在一个特定的时刻只允许一个人对某个文件进行修改。这种方案的问题是它有一点过于严格了,经常会阻塞用户的使用。锁定可能会带来管理问题。锁定可能导致不必要的串行工作。锁定可能导致错误的安全状态,文件可能相互依赖,复制修改合并方案,Subversion、CVS以及其他一些版本控制系统使用“复制修改合并”模型来代替锁定。每一个用户的客户端软件从中央仓库创建出一份个人的工作副本仓库中文件和目录的本地映射。用户就可以并行工作,修改手中的私有副本。这些私有副本合并成为一个全新的版本。版本控制系统常常需要合并,但是最终,操作者本身必须负责让合并工作正确进

12、行。,冲突(conflict),复制修改合并模型会带来冲突的问题用于解决冲突的时间远远少于锁定系统所带来的时间浪费。没有系统可以强制用户完美的交流,没有系统可以检测语义上的冲突解决冲突的关键是用户交流,模型选择,锁定-修改-解锁模型被认为不利于协作,但有时候锁定会更好。拷贝-修改-合并模型假定文件是可以根据上下文合并的:就是版本库的文件主要是以行为基础的文本文件(例如程序源代码)。但对于二进制格式,例如图片或声音,在这种情况下,十分有必要让用户轮流修改文件,如果没有线性的访问,有些人的许多工作就最终要被放弃。SVN也支持锁定-修改-解锁模型。,实际中的 Subversion,工作副本Worki

13、ng Copies 修订版 Revision混合型修订版,工作副本,一个 Subversion 的工作副本其实就是本地系统中的一个普通的文件目录树。可以使用任何方式来编辑这些文件。如果是源代码文件的话,你也可以像通常情况那样去编译它们。工作副本是你的私人工作区。如果你不明确的要求,Subversion 绝不会合并其他人的修改,也不会让其他人看到你做的修改。,工作副本,在你已经修改完工作副本中的文件,并且确信修改正确后,就可以将这些修改公开给同一个项目中的其他工作人员。Subversion 提供了将文件写入仓库的命令。工作副本中也包含一些额外的文件。它们是由 Subversion 创建和维护的,

14、用来辅助完成这些命令。最典型的情况是,每一个目录都包含一个叫做.svn 的子目录。该目录也被称为“工作副本管理目录”。一个 Subversion 的仓库会包含几个项目,而每一个项目都是仓库的目录的一个子目录。这样,用户的工作副本也就对应于仓库中一个特定的子目录。,SVN的修订版,一个 svn commit 操作可以将任意数量的文件和目录的修改发布作为一个单独的原子事务来处理。在仓库中,每一次提交都被作为一个原子事务来对待。每当仓库接受一次提交,仓库中的文件系统目录都会创建一种新的状态,叫做一个修订版。每一个修订本都被赋予一个唯一的自然数,并且每一个修订版的数字都比前一个要大。刚刚建立的仓库的初

15、始的版本是 0,只包含一个空的根目录。Subversion 的修订版编号是针对整个目录树的,而不是某一个独立的文件。如图所示:,修订版,设想一个修订版编号的数列,从 0 开始,从左延伸到右。每一个修订版编号都对应一个画下面的目录树,而每一个目录树就是在每一次提交之后的仓库的快照。,混合型修订版,一般的原则上,Subversion 努力使自己尽可能的灵活。一个典型的灵活性的体现就是允许工作副本中包含有混合的修订版编号的能力。在完成向仓库的提交之后,刚刚提交的文件和目录就拥有了最新的修订版编号,而其他文件没有。,subversion/cvs/vss比较,三、Subversion常用功能讲解,基本术

16、语主要讲解SVN 客户端工具的常用命令通过本部分的学习,可以操作所有任务在日常使用subversion版本控制系统,术语,基本修订版(revision)存储库接受的每一次修改产生新的修订版HEAD:存储库中最新版本BASE:工作拷贝中一个条目的修订版本号,如果这个版本在本地修改了,则“BASE版本”就是这个条目在本地未修改的版本。分支(branches)标记(tags)合并(merging),Subversion客户端工具,命令行工具通过命令行方式,主要命令包括:svn:基本svn命令svnadmin:存储库管理svnlook:存储库查看TortoiseSVN与windows资源管理器集成su

17、bclipse与eclipse集成,Subversion常用操作,import将本地目录导入存储库checkout从存储库创建目录树的本地工作拷贝update将存储库中文件同步到本地工作拷贝中commit本地工作拷贝中文件修改提交到存储库中add将本地文件加入到存储库中remove从存储库中删除一个文件(保留历史记录).move在存储库中讲一个文件移到另一个位置,Subversion推荐目录结构,存储库项目名trunk:主版本branches:分支版本(独立版本)tags:标记版本,比如发行版 v 1.0/v 2.0等等,工作拷贝、存储库同步的状态,Svn常用命令介绍,HelpImportCh

18、eckout基本的工作周期:Update your working copysvn updateMake changes add delete copy move,Svn常用命令介绍,Examine your changesstatusdiffrevertMerge others changesMergeResolvedCommit your changescommit,IMPORT,import:提交未纳入版本控制的文件或目录树至档案库 用法:import PATH URL 递归地提交 PATH 的拷贝至地址(URL)。如果省略 PATH,默认为.。父目录会依需要于档案库内建立。举例:svn

19、 import./kav8 http:/10.10.11.226:1976/hermes/svtest/trunk-m add kav8,IMPORT,Central Repository,Local Workspace(s),A,import,A,Central Repository,Local Workspace(s),A,before,after,in sync,CHECKOUT,checkout(co):从repository中取出文档,在本机建立工作副本(working copy)开始工作前的前置动作用法:checkout URL PATH例如:svn co http:/10.10.

20、11.226:1976/hermes/svtest,CHECKOUT,Central Repository,Local Workspace(s),checkout,A,Central Repository,Local Workspace(s),A,before,after,in sync,A,EXPORT,Export:导出一个无版本控制的目录树副本用法:svn export-r REV URLPEGREV PATHsvn export-r REV PATH1PEGREV PATH2例如:svn export http:/10.10.11.226:1976/hermes/svtestExpor

21、t与Checkout的区别export导出的副本无svn附加文件,不在服务器的版本控制下checkout会在本地建立一个工作区,可以修改和提交,UPDATE,将repository上的版本整合到本地端的工作副本(workspace)可能会出现冲突,需要手动解决用法:update PATH.例如:svn update At revision 25.,UPDATE,Central Repository,Local Workspace(s),update,A,Central Repository,Local Workspace(s),A,before,after,in sync,A,A,COMMIT

22、,提交操作使workspace与repository保持同步本地端的修改包含:文件内容修改、文件目录删除需要发布到repository时用法:commit PATH.m LOG_MSG日志信息必须提供,但可以是空的 例如:svn ci-m add a wordSending dir1/222Transmitting file data.Committed revision 26.,COMMIT,Central Repository,Local Workspace(s),commit,A,Central Repository,Local Workspace(s),A,before,after,i

23、n sync,A,A,COMMIT,最好能够一次提交概念性、功能性或任务性的修改确保源代码编译通过,做出修改(Make changes),Add:增加文件或者目录到资源库中,然后commit。条件是该文件或者目录已经在相应的目录上。Delete删除在库中的文件或者目录,然后commit。Copy拷贝文件,然后commitMove移动文件或目录到另外目录中,相当于拷贝、删除的组合。以上的命令是针对工作副本进行的,所以要commit才有效,检验修改(Examine your changes),Status显示工作拷贝目录与文件的状态。用法:status PATH.svn status wc M w

24、c/bar.c A wc/qax.cDiffdiff(di):显示两个路径中的差异 svn diff-r 19:25 Project.javaRevert恢复原始未改变的工作拷贝文件(恢复大部份的本地修改),合并修改(Merge others changes),Merge将两个来源之间的差异应用至工作拷贝路径 Resolved移除工作拷贝的目录或文件的 冲突 状态,Other userful commands,CleanupListCatLogmkdir,常见的STATUS,A 预定要添加的项目。D 预定要删除的项目。M 项目已经修改了。U 文件更新了(从服务器收到修改)R 项目在工作拷贝中已

25、经被替换了。这意味着文件预定要删除,然后有一个同样名称的文件要在同一个位置替换它。C 项目的内容(相对于属性)与更新得到的数据冲突了。?项目不在版本控制之下。!项目已经丢失(例如,你使用svn移动或者删除了它)。这也说明了一个目录不是完整的(一个检出或更新中断)。,分支(BRANCH),独立于主干(trunk)的“新项目”新项目开始于某一稳定版本的revision,通过revision copy得到分支的基本概念正如它的名字,开发的一条线独立于另一条线,如果回顾历史,可以发现两条线分享共同的历史例子:svn cp http:/10.10.11.226:1976/hermes/svtest/tr

26、unk http:/10.10.11.226:1976/hermes/svtest/branch/bc_3_0-m“create branch from r101,建立BRANCH的时机,开发可能会对主分支产生影响从某一版本产生独立的“特殊”产品解决BUG增加新功能,标签(TAG),与BRANCH类似,给稳定的版本做记号一个标签只是一个项目某一时间的“快照”,在Subversion里这个概念无处不在每一次提交的修订版本都是一个精确的快照。从TAG中取出的代码可以编译成独立的产品一般与Release产品一一对应例子:svn cp http:/10.10.11.226:1976/hermes/sv

27、test/trunk http:/10.10.11.226:1976/hermes/svtest/tags/tag_release_3_0-m“create tag from r101,BRANCH与TAG的区别,branch和tag,对于svn都是使用copy实现的,所以他们在默认的权限上和一般的目录没有区别。至于何时用tag,何时用branch,完全由人主观的根据规范和需要来选择,而不是强制的。一般情况下,tag,是用来做一个milestone的,不管是不是release,都是一个可用的版本。这里,应该是只读的。更多的是一个显示用的,给人一个可读(readable)的标记。Branch 是

28、用来做并行开发的,这里的并行是指和trunk进行比较。例如:3.0开发完成,这个时候要做一个tag,tag_release_3_0,然后基于这个tag做release。trunk进入3.1的开发,但是3.0发现了bug,那么就需要基于tag_release_3_0做一个branch,branch_bugfix_3_0,基于这个branch进行bugfix,等到bugfix结束,做一个tag,tag_release_3_0_1,然后,根据需要决定branch_bugfix_3_0是否并入trunk。,合并(MERGE),合并BRANCH的修改到TRUNK合并主分支的最新版本到工作副本BUG修正后

29、将BUG去除的代码合并到其他“特殊”BRANCH可以用来恢复旧版本merge:Apply the differences between two sources to a working copy path.usage:1.merge sourceURL1N sourceURL2M WCPATH2.merge sourceWCPATH1N sourceWCPATH2M WCPATH3.merge-c M|-r N:M SOURCEREV WCPATH。其实,第一个URL(称之为左边),为起始状态;第二个URL(称之为右边),为最终状态,取最新的;最后一个是接收区别的工作拷贝(通常叫做合并的目标

30、)。,合并(MERGE),svn没有恢复旧版本的直接功能,不过可以使用svn merge命令恢复。例子:当前HEAD为14,而我要恢复成10版本,怎么做?用svn merge:svn updatesvn merge-revision 14:10 PATHsvn commit-m restore to revision 10”Merge原理是比较指定版本的差异,然后把这些差异应用到本地工作副本,而-r后的14:10,是指相对于版本14来说版本10的变化(注意,这个版本的次序很重要。),也就是相对版本14,版本10添加了哪些文件或目录,以及哪些文件添加了哪些行删除了哪些行。又因为本地版本是最新的1

31、4,所以把这些差异应用到本地版本时就等于把14改变成10,其效果等于还原到版本10。,冲突,产生原因当团队协同工作的时候,多人同时操作一个文件。当有人操作完成后,将该文件提交到SVN上。这样,其他人的本地文件与SVN上的文件版本不一致。当另一人操作完成后,提交该文件时,就会出现冲突对于每一个冲突的文件,Subversion放置三个额外的未版本化文件到你的工作拷贝:filename.mine 更新前的文件,最新更改的内容。filename.rOLDREV 更新操作以前的BASE版本文件,在上次更新之后未作更改的版本。filename.rNEWREV 服务器的版本,对应版本库的HEAD版本。这里O

32、LDREV是本地.svn目录中的修订版本号,NEWREV是版本库中HEAD的版本号。,冲突的解决,面对文件冲突,您可以选择以下三种方式解决冲突:1.“手动”合并冲突文本(检查和修改文件中的冲突标志)。-需要团队成员交流2.如果希望取消自己的修改,可以拷贝Subversion为你生成的文件替换你的工作拷贝用某一个临时文件覆盖你的工作文件。3.运行svn revert 来放弃所有的修改。解决了重提之后,运行svn resolved,删除了临时文件,之后可以提交了。,如何避免冲突,养成良好的习惯,在修改文件之前,先进行一次update操作当修改完成后,及时commit,不要在本地停留时间过长在多人协

33、作时,尽量修改自己撰写的部分,不要修改其他部分多人协作时,增加交流出现冲突很正常,可以通过前面的三个方法解决,不要相互覆盖,四、客户端工具TortoiseSVN,TortoiseSVN介绍TortoiseSVN的使用,TortoiseSVN介绍,Windows操作系统客户端图形化界面,集成了svn和svnadmin命令行工具的功能。该客户端集成于资源管理器功能中,使用方便,易于掌握。网上可搜索下载,直接安装TortoiseSVN-1.6.10.19898-win32-svn-1.6.12.msi,方法同一般软件安装相同,TortoiseSVN使用介绍,一旦该客户端安装成功,在指定目录单击右键,

34、弹出菜单中,增加了几项,如图所示:,TortoiseSVN使用介绍,如上图所示,在资源管理器菜单中增加了,svn checkout 命令菜单和其他命令,诸如:浏览指定的资源库、创建资源库、从资源库中导出资源、从指定目录中导入到资源库中。还有一些有关设置tortoisesvn工具的参数。如果指定的目录已经被纳入到特定的资源库中,那弹出的菜单参数更多,如目录private已经被subversion管理了,它就是一个工作副本,如下图所示:,TortoiseSVN使用介绍,TortoiseSVN使用介绍,如上图所示,弹出菜单中含有更多的svn命令UpdateCommit含有svn的所有命令,但是操作比

35、svn命令行方式方便多了。通过该客户端可以很快掌握svn命令,同时很好的对自己所属的工作拷贝进行管理,TortoiseSVN图标状态信息,七种图标:表示版本控制状态正常表示本地工作复本已经被修改过,等待被提交表示出现了文件内容冲突表示该文件被他人锁定表示该文件被自己锁定表示当前文件夹下的某些文件已经被计划从版本控制中删除,或是该文件夹下某个受控的文件丢失了。加号表示有文件或目录已经加入“变更列表”中。,五、SVN使用中常见问题,如果不小心删除了子目录.svn,最简单的解决办法是删除包含的目录(普通的文件系统删除,而不是svn delete),然后在父目录运行svn update,Subvers

36、ion客户端会重新下载你删除的目录,并包含新的.svn。svn:Working copy trunk/src locked svn:run svn cleanup to remove locks(type svn help cleanup for details)异常操作导致目录没有解锁。一个简单的重现方法:在.svn 目录下创建空的名为 lock的文件解决办法:使用命令行 svn cleanup 或者类似的“清理”动作删除锁定,SVN使用中常见问题,Svn up时提示:svn:Cant recode string原因:SVN服务器中的内容可能包含特殊字符,字符集的问题解决办法:(1)SVN服

37、务器上更改相关文件名为非特殊字符或者删除特殊字符的文件(夹);(2)LINUX环境下,设置环境变量为包含特殊字符的字符集,如未知,可使用UTF-8字符集:添加以下环境变量/.bash_profile:export LANG=en_US.UTF-8,养成良好的SVN使用习惯,在修改文件之前,先进行一次update操作经常使用svn st查看工作副本修改的代码,对显示修改的代码使用svn diff比较,检验修改的文件当修改完成后,及时commit(及时提交不等于随意提交)在提交时最好指明要提交的文件,这样能避免错误的提交提交时,日志信息一定要写,并且要写得清楚易懂出现冲突时,通过沟通交流解决,不要相互覆盖如果使用分支的开发方式,要经常的合并,谢谢!,

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号