`
阅读更多

      SVN是一种版本管理系统,前身是CVS,是开源软件的基石。即使在沟通充分的情况下,多人维护同一份源代码的一定也会出现混乱的情况,版本管理系统就是为了解决这些问题。

Svn是严格区分大小写的,存储中路径的名字只有大小写不同,也会当作不同的路径处理。

SVN的版本概念

一个是服务器版本,每一次提交svn都会将版本号加1,无论你是修改了文件,还是添加删除了,甚至修改一下文件夹的svn属性,只要你提交都会更新版本;
第二个是本地基础版本,也就是你上次进行update之后的和svn服务器上的版本,比如你update时服务器上是reverion11你的本地基础版本就是reverion11,无论别人改了什么,服务器上更新了多少版,只要你不执行update则你的基础版本永远是reverion11;
第三个是工作版本,就是你当前改着的版本,工作版本是基于基础版本的,如果没改,工作版本就和基础版本一致,如果你改了,你的工作版本就是从基础版本修改过来的。

下载Subversion服务器程序

下载Subversion的Windows客户端TortoiseSVN

服务器和客户端安装

建立版本库(Repository):

运行Subversion服务器需要首先要建立一个版本库(Repository),可以看作服务器上存放数据的数据库,在安装了Subversion服务器之后,可以直接运行,如:  

svnadmin create D:\svndemo\repository  

就会在目录D:\svndemo\repository下创建一个版本库。

我们也可以使用TortoiseSVN图形化的完成这一步:

在目录D:\svndemo\repository下"右键->TortoiseSVN->Create Repository here...“, 然后可以选择版本库模式, 这里使用默认即可, 然后就创建了一系列目录和文件。 

例如:使用一个版本库管理多个项目,project1和project2。

配置用户和权限:

来到D:\svndemo\repository\conf目录,修改svnserve.conf:

# [general]

# password-db = passwd

改为:

[general]

password-db = passwd 然后修改同目录的passwd文件,去掉下面三行的注释:

# [users]

# harry = harryssecret

# sally = sallyssecret

最后变成:

[users]

harry = harryssecret

sally = sallyssecret 

运行独立服务器:

在任意目录下运行:

svnserve -d -r D:\svndemo\repository 我们的服务器程序就已经启动了。注意不要关闭命令行窗口,关闭窗口也会把svnserve停止。

初始化导入:

来到我们想要导入的项目根目录,在这个例子里是E:\svndemo\initproject,目录下有一个readme.txt文件:  右键->TortoiseSVN->Import... URL of repository输入“svn://localhost/project1” 或“svn://192.168.5.49/project1”ok 完成之后目录没有任何变化,如果没有报错,数据就已经全部导入到了我们刚才定义的版本库中。  需要注意的是,这一步操作可以完全在另一台安装了TortoiseSVN的主机上进行。例如运行svnserve的主机的IP是192.168.5.49,则URL部分输入的内容就是“svn:// 192.168.5.49/project1”。

基本客户端操作:

取出版本库到一个工作拷贝:

来到任意空目录下,在本例中是E:\svndemo\wc1,运行右键->Checkout,在URL of repository中输入svn:// 192.168.5.49/project1,这样我们就得到了一份工作拷贝。

 

在工作拷贝中作出修改并提交:

打开readme.txt,作出修改,然后右键->Commit...,这样我们就把修改提交到了版本库,我们可以运行。  

察看所作的修改: readme.txt上右键->TortoiseSVN->Show Log,这样我们就可以看到我们对这个文件所有的提交。在版本1上右键->Compare with working copy,我们可以比较工作拷贝的文件和版本1的区别  

 

SVN基本操作之svn checkout
作为svn的用户,拿到一个svn地址,我们首先做的一个事情就是svn checkout,将svn上的关联到本地的一个文件夹中。这个文件夹最好是空的文件夹,或者确保没有和svn上相同名称的路径,当然这也说明这个操作是个连线操作。我们一般在执行checkout的时候只要给出svn的URL和本地的路径两个内容就可以了。这样svn上最新的数据会被传送到这个文件夹,目录结构会自动建好,svn上的文件会自动出现在对应的文件夹中。当然如果你愿意也可以选择一个旧的版本,或者只包含一层目录或者只是这个文件夹中的文件。或许你发现了,每一个文件夹中比服务器上的内容多了个.svn文件夹,这个文件夹中存放着文件夹的属性,这个文件夹中的每个文件的属性、版本还有对应版本的一个副本。

SVN基本操作之svn update
这个操作就是将本地的的数据更新到svn上的某个版本,默认的操作是更新到最新版本,这个操作也是个连线操作。在这个过程中如果有人删除了文件,它会你机器上的文件删除,如果别人改了某个文件,会将这个文件更新。如果你修改了某个文件,别人删除了它,则这个文件不会被删除,只会和svn没关系了。如果你修改了某个文件,而这个文件别人也修改了,在更新的过程中就会试图自动将你的修改合并,如果成功,他的内容就是你修改的和别人修改的内容的并集,如果失败,svn就会将这个文件标记为冲突。冲突的问题我们放在下个说。

SVN基本操作之svn resolve
使用svn意味着你已经走在了工作在编辑和合并的道路上,那么冲突的时候svn做了什么,出现了冲突怎么解决?
在标记为冲突的过程中,如果是文本文件,如cpp和h文件,svn会修改它让他不能进行编译,并产生一个theirs和mime,分别包含svn服务器上的和我自己原来的版本。
如果是二进制文件,svn不会修改它,而会在目录中产生一个r??和r??这两个r??一个是你update之前的svn基础版本,就是你上次执行update的版本,一个是svn上的当前update下来的版本。
你可以选择直接使用theirs或者使用mime或者退回到上一个update版本,或者将两个文件放在一起手工合并作为解决的方法。
这个操作是离线操作。

SVN基本操作之svn commit
svn的commit操作就是将修改从工作拷贝发送到版本库并将版本标记为新的版本,这个过程中如果有人已经对这个版本进行了操作,也就是你的本地基础版本和服务器不同,将会强制你执行一个update操作,这个操作是个连线操作。commit的过程仅仅是将你本地的一些修改提交到svn中让svn上的和你的一致,在提交之前必须已经解决了需要提交文件已有的冲突才行。

SVN基本操作之svn add
如果一个文件不受svn管理,你需要把它添加到svn中,这个操作是个离线操作,仅仅是把这个文件标记为需要添加,真正的添加到svn存储的操作将在下一次commit时执行。这个过程中需要注意不要把一些不必要的文件比如编译的临时文件添加到svn。

SVN基本操作之svn import
当然你可以将一些文件直接添加到svn而不想修改这些文件的svn管理状态,可以选择将它们导入到svn。注意如果将一个文件导入,则给出的url就是它添加到svn的最终文件名,如果将一个文件夹导入,则会将根据目录树所有的子文件和文件夹放到对应的url的对应目录树中,根文件夹不会被添加。
这个操作是连线操作。

SVN基本操作之svn cleanup
这个操作清理整个所选择的文件夹及其子文件夹,但是它不是清理垃圾文件什么的,这肯定不是svn的工作。它也不会把冲突自动解决,如果能自动解决,在更新的时候为什么不做。如果你在某个svn操作时强制中断了,比如svn的操作程序停止相应或者以外终止,就有可能导致文件夹处于锁定状态,这时需要清理。如果你的文件夹中的很多文件时间戳发生了变化,也最好执行以下cleanup这样可以加速svn操作的执行。
这个操作是离线操作。

SVN基本操作之svn delete
既然有方法添加文件,就一定有方法删除,虽然你看到的效果是文件直接被删除了,但是实际上和添加一样,这个操作是个离线操作,操作的结果将被标记,下次commit时服务器上的文件才会被删除。

SVN基本操作之svn revert
如果你的修改出现了问题,或者添加或者删除了错误的文件,等等想还原操作,在commit之前可以执行revert操作,退回某步操作,这样这些修改都会被还原到基础版本状态。这个操作不会和svn服务器有关系,不会连接服务器也不会更新文件,只是简简单单的回复到基础版本。
这个操作是个离线操作。

SVN基本操作之svn diff
这个操作就是比较你的工作版本和某个svn版本的区别,当然默认是你的基础版本,因为你的工作版本就是从基础版本修改过来的么。
在和基础版本比较时是个离线操作,和历史版本比较时是连线操作。

SVN基本操作之svn export
这个操作可以将一个已经在svn管理下的文件夹中的所有工作版本导出到一个文件夹中,或者直接从svn服务器上将一个版本导出到一个文件夹中。导出的文件夹不再在svn的管理控制下,也不会有.svn目录,当然也不会包含不在svn管理下的文件。
在导出工作版本时是个离线操作,从svn直接导出时是连线操作。

SVN基本操作之svn copy
操作的名字显而易见,就是复制操作,在svn上复制文件有什么好处呢,为什么不直接复制文件再添加到svn呢。这个问题我也考虑过,svn copy可以将文件在复制之前的历史保留下来,这应该是最大的好处了。
这个操作是离线操作,需要提交才起效。

SVN基本操作之svn move
和copy一样,历史的留存也是和复制后删除源文件这个方式最大的区别,并且它也是离线操作,需要提交才起效。

SVN基本操作之svn lock
如果你想独占修改这个文件,可以把文件锁定,这样就可以锁定这个文件,这样别人必须等待你提交了修改或者释放了锁才能提交他们的修改。这个操作不会对别人的svn本地存储有什么影响,而只是无法进行数据提交。如果某个文件有svn:needs-lock这样的标志时,文件会被设置为只读,提示你需要获得锁来修改。当然你也可以把文件的属性修改直接修改,这个只是防君子不防小人的。
这个操作时连线操作。

SVN基本操作之svn unlock
虽然是unlock但是实际上这个我们平常不会将他用来和lock配对,因为commit操作时,svn默认自动将锁释放了。这个操作的用处是在你得到锁了之后,又不想锁定这个文件时执行的。还有就是如果别人锁定了这个文件,想强制把这个文件解锁,就可以强制将这个文件解锁。
这个操作时连线操作。
解决代码冲突:

如果commit时出现“You have to update your work copy first.”红色警告,说明版本库中的此文件已经被其他人修改了。请先点“ok”按钮退出。执行update,然后再commit。

如果修改与update得到的代码不冲突,则自动合并。如果冲突(比如对同一行代码进行了修改),则出现”One or more files are in a conflicted state.“红色警告,并产生几个文件记录冲突。一般情况下,我们不要直接编辑冲突文件。而按照以下操作手工解决冲突。

在资源管理器中,选择commit时冲突的那个文件,鼠标右键菜单选择”Edit conficts”。

出现界面,分为”Theirs”、”Mine”和”Merged”3部分,表示”别人修改的内容”、 ”我修改的内容”和”合并后的结果”3部分。我们是要将”别人修改的内容”和”我修改的内容”有取舍地合并起来,形成”合并后的结果”。

合并一般分为4种情况:

保留”我的修改”,舍弃”别人的修改”。鼠标右键点击Mine框的相应行,点击”Use this text block”。
舍弃”我的修改”,保留”别人的修改”。鼠标右键点击Theirs框的相应行,点击”Use this text block”。
同时保留”我的修改”和”别人的修改”,并将”我的修改” 放在前面。鼠标右键点击Mine框的相应行,点击”Use text block from mine before theirs”。
同时保留”我的修改”和”别人的修改”,并将”别人的修改”放在前面。鼠标右键点击Mine框的相应行,点击”Use text block from theirs before mine”。
合并完成,Ctrl+S存盘,退出。

然后,在资源管理器中,选择冲突文件,鼠标右键菜单选择”Resolved”,标记冲突已解决。系统会自动删除因冲突而新建的文件。此时,就可以继续进行commit操作了。

其实多数时候都是不管别人的修改,添加自己的修改,用手工复制粘贴一下自己的修改,再commit.

分享到:
评论

相关推荐

    配置管理工具SVN介绍及使用.ppt

    配置管理工具SVN介绍及使用

    svn介绍和安装处理PPT

    这份“svn介绍和安装处理PPT”将深入探讨SVN的基本概念、工作原理以及安装过程。 首先,让我们了解一下SVN的基本概念。SVN的核心是版本库,它存储了所有文件的历史版本。每个文件都有一个唯一的标识符,称为修订...

    SVN介绍和日常使用.ppt

    【SVN介绍与日常使用详解】 SVN,全称Subversion,是一款开源的版本控制系统,设计初衷是为了弥补CVS( Concurrent Version System)的不足。与传统的版本控制系统如VSS(Visual SourceSafe)采用的锁定-修改-解锁...

    svn 介绍及使用安装

    ### SVN介绍及使用安装详解 #### 一、SVN简介 **SVN**(Subversion)是一种广泛使用的版本控制系统,主要用于管理软件项目的多个版本。当多个开发者需要协作开发同一个项目时,SVN提供了一种有效的方式来追踪每一次...

    svn 介绍

    **svn 介绍** **为什么我们需要源代码管理** 源代码管理对于任何软件开发团队都是至关重要的。它解决了多人协作开发中的诸多挑战,确保代码的稳定性和可维护性。以下是几个主要理由: 1. **代码回归**:通过源...

    Svn相关学习资料以及视频

    SVN,全称为Subversion,是一款广泛应用于软件开发领域的版本控制系统。它允许团队成员协同工作,跟踪文件和目录的变化,并管理项目的多个版本。本压缩包提供了丰富的 SVN 学习资源,包括安装教程、文档和视频,旨在...

    svn 介绍与user实操指南

    对于SVN版本管理进行相应介绍,对常用svn命令进行简介,对版本库进行介绍并具有实操性

    SVN使用介绍

    【SVN使用介绍】 SVN,全称Subversion,是一个开源的版本控制系统,用于管理和跟踪文件及目录在不同时间的更改。它允许多人协同工作,同时保持代码的历史记录,便于团队成员之间的协作和代码管理。在软件开发过程中...

    VS2022软件配置管理说明-visualSVN+TortoiseSVN+AnkhSvn汇编.pdf

    该文档主要介绍了Visual Studio 2022下的软件配置管理工具的配置和使用方法,涵盖了Visual SVN、TortoiseSVN和AnkhSvn三个工具的安装、配置和使用方法。 ### 1. SVN 和 VI SUAL SVN 介绍 SVN(Subversion)是一种...

    VS集成SVN和AnkhSvn插件

    三、AnkhSVN介绍 AnkhSVN是专为Visual Studio设计的免费SVN客户端插件,它完全集成在VS的菜单和工具栏中,提供了与VS原生功能相似的用户体验。AnkhSVN支持多种VS版本,包括Visual Studio 2010到Visual Studio 2019,...

    4.13svn介绍.avi

    详细讲解svn,默认情况下,在下载远程代码时,SVN不会新建当前选定的远程文件夹,例如对应上面的图片中,SVN是不会新建cgi_oss目录的,代码下载时,直接在sourcecode下列出cgi_oss目录下的子目录及文件,而不包含cgi...

    AnkhSvn-2.5

    1. **AnkhSvn介绍**:AnkhSvn是一个开源项目,由志愿者开发者维护和更新。它为Visual Studio提供了对Subversion版本控制系统的支持,使开发者可以在熟悉的IDE内进行版本控制操作,如提交、更新、合并、冲突解决等。 ...

    svn使用教程

    五、svn 介绍 svn 是一种版本控制系统,主要用于软件开发中的版本控制和项目管理。svn 可以帮助开发团队协作开发,解决代码冲突、版本控制、权限控制等问题。svn 的使用方法有复制-修改-合并方案和锁定-修改-解锁...

    SVN安装+拉取代码.mov.zip

    【SVN介绍】:Subversion是一个开源的版本控制系统,用于管理文件和目录的变更历史,使得多人协作开发时可以有效地跟踪和控制代码的修改。SVN通过存储文件的不同版本,允许用户回滚到以前的状态,避免数据丢失,并且...

    svn使用简介ppt

    主要是对svn的简单使用介绍,包括windows和linux上的使用

    SVN操作手册及在Delphi中使用

    **一、SVN 介绍** SVN,全称 Subversion,是一种版本控制系统,用于管理软件项目的源代码和其他文件,记录文件和目录的变更历史,便于团队协作开发。它允许开发者查看历史版本、回滚到旧版本、合并不同分支的修改,...

    AnkhSVN(64位)中文版 2.5 2.7 VS2013 VS2015两个安装包

    1. AnkhSVN介绍: AnkhSVN是一款开源项目,它为Microsoft Visual Studio提供对Subversion(SVN)的支持。Subversion是一款广泛使用的版本控制系统,用于追踪文件和目录的修改,以便多人协作开发。AnkhSVN将这些功能...

    VisualSVN_TortoiseSVN_AnkhSvn_软件配置管理说明

    简介 第1章 VS项目软件配置工具介绍 1 .1 SVN和VISUALSVN介绍 1.2 必备软件 ...4.1 ANKHSVN介绍 4.2 ANKHSVN安装 4.2 ANKHSVN连接VISUALSVN SERVER 下载源项目 4.3 ANKHSVN开发项目时其它的操作流程

    AnkhSvn-2.5.12440.9

    一、AnkhSvn介绍 AnkhSvn是一个开放源码的Visual Studio插件,它将强大的版本控制功能无缝地整合到Visual Studio开发环境中。通过AnkhSvn,开发者可以直接在IDE内部执行常见的SVN操作,如版本提交、更新、合并、差异...

    SVN版本控制安装及使用说明

    **一、SVN 介绍** SVN(Subversion)是一种开源的版本控制系统,用于管理文件和目录的变更历史,支持多人协同工作,使得团队成员可以在同一份代码上进行修改并合并更改,同时保持代码的历史记录。它允许用户追踪...

Global site tag (gtag.js) - Google Analytics