原文地址:http://www.weixingon.com/s/visualsvn+%E4%B8%AD%E6%96%87

1.几种代理管理工具的适用场景

A.如果你的项目是5-6人的小团队,那么使用VSS已经可以了。

B.如果是几十个人的团队,团队中需要创建代码分支,或者需要跨平台,跨地区开发,那么SVN是一个不错的选择。

C.对于较大型的项目,如果是使用VS开发,那么使用TFS是个不错的选择,和微软自己的产品相结合,可以说无缝。并且提供了项目 计划、测试管理、代码评审等一揽子功能,如此强大的项目管理工具,我们不能说他不好,只是比较重量级,光就服务端安装包就2G多,并且需要结果 SqlServer数据库工作。

D.如果你的项目是开源项目开发人数不定,并且存在较多分支,那么推荐使用GIT。

2.SVN简介

名称:SVN(Subversion的简称,开源的版本控制系统)

厂商:开源项目(CollabNet发起并提供启动资金,目前Wandisco是贡献最多的全职Subversion开发者并担任releasemanager.)

功能:支持创建分支、标志,支持回滚、事务等。

优点:安装操作都比较简单,支持跨平台,跨地区管理代码;有较快的速度;支持文件重命名;支持不锁定开发;管理方便,符合大众思维习惯;易于上手,代理一致性较高。

缺点:适合中小型项目,人数在几十人为佳;不适合人数较多的项目,比如开源项目;服务器开销较大,数据库容易暴增;不能离线工作,没连接服务器,不能进行对比,还原,提交等工作。

升级:开源项目,管理比也比较规范,升级很及时,不断有新版本出来,本文编写时就有新版本1.9.3.27038更新了(2天前更新,可见很及时)。

推荐:★★★★(中、小型项目适用)

3.SVN的安装和使用

首先SVN和其他版本控制工具一样,有Server端和Client端,下面分别介绍安装和使用。

3.1安装包下载

安装包,我们可以从官方网站下载,官网提供了Linux和Windows各种版本,可以使用,我们主要介绍Windows下的安装使用

下载URL:http://subversion.apache.org/packages.html

拉到最底下

如上图,有两个我们需要的安装包,先点击第一个"TortoiseSVN"这是一个客户端工具,主要用于和WINDOWS资源管理器绑定,进行文件管理

分别提供了32位和64位两种版本,根据我们操作系统下载对应的。下面是各种语言包。我们下载简体中文

然后,我们点击图1的第二个地址,进入服务端和VS插件下载网站,如下图:

我们下载“VisualSVNforVisualStudio”这个主要用于VS开发源代码版本控制。

再下载“VisualSVNServer”这个就是服务器上需要安装的管理工具。

一共有四个安装包,下载后如下:

我是64位操作系统,下载的全是64位,可根据自己的操作系统下载32位或64位

3.2SVN服务端安装

双击下载的“VisualSVN-Server-3.5.0-x64.msi”进入SVN服务器安装

下一步

选择同意声明,点下一步

按默认,安装服务器及管理员工具和命令行工具,点下一步

这里我们选择标准版即可,企业版需要每台服务器支付950美元,标准版免费,并且其功能基本可以满足我们的使用需要。点下一步

这里Location为安装路径,Repositorys为数据库存放地址,下面是端口号和是否使用安全连接,按默认即可,点下一步,

配置完成,点Install安装

安装完成,选择启动SVN服务器。

3.3SVN服务端使用

3.3.1创建版本库

打开刚才安装好的SVN服务器端,“VisualSVNServerManager”如下

服务端主界面右边为一些状态信息,左边是我们创建的版本库,用户及组。

在版本库上右击,打开菜单,分别为创建版本库,导入已存在的版本库,浏览。

我们点击“CreateNewRepository..”创建一个新的版本库,打开窗口如下:

这里是选择版本库类型,我们按默认,点下一步

这里输入一个版本库名称,点下一步。

这里我们按默认,选择创建一个空的版本库,点下一步,

这里是给新创建的版本库,设置认证方式,我们按默认,选择“所有用户都具有读写权限”点击创建,完成版本库的新建。

点完成,结束版本库创建。

3.3.2创建用户

下面创建用户,如下图:

右击Users打开创建用户对面框,输入用户名和密码,点击OK,

右击组,点击创建组

输入组名Dev,点击下面的添加,把前面创建的用户yu加入到该组,点OK

3.3.3用户授权

在前面创建的版本库名MyObject上右击,打开菜单中选Properties...

打开的权限窗口如下,我们点击Add..添加用户或组,在这里,我们可以选择组,则表示该组下的所有都具有相应权限,也可以单选用户

我们选择dev组名,然后在Permissions中选择可读可写权限,如下图

至此,服务端配置完成。

3.4SVN客户端安装

下面我们进行SVN客户端安装,找到我们之前下载的安装包,

先安装“小乌龟”TortoiseSVN-1.9.3.27038-x64-svn-1.9.3.msi,再安装语言包LanguagePack_1.9.3.27038-x64-zh_CN.msi

客户端的安装没什么好说的,全程下一步。

语言包的安装也是全程下一步(如果喜欢英文版,这步可以省略)

语言包安装后,并不会马上显示所安装的语言,需要一步设置。

我们在开始菜单中,找到TortoiseSVN的设置,也可以在你的电脑上任何文件上右键打开setting

打开设置窗口,点击General,在右边的语言选项中,选中简体中文,即可完成语言设置。

至此,客户端安装完成。

3.5SVN客户端基本操作

这节是重点,将学习如何使用SVN进行版本控制

3.5.1签出项目文件

首先我们在客户端电脑上创建一个项目文件夹,MyObject

右击项目文件夹,点签出

打开签出窗口,

在这里,我们要输入前面服务端中创建的版本库地址,我们可以在Server端Copy这个地址,打开Server端

右击版本库,点击复RUL,然后粘贴过来

签出深度有几项可以选择,这里我们默认全递归,即可。点击确定

这时会弹出一个认证窗口,在这里需要验证一下用户,使用我们服务端创建的用户

下面的保存认证,默认为选中,选中后,下次再执行签出等操作,则无需再次验证。如果本台电脑为你一个人使用,可以保存,如多人使用,请注意安全。

点击确定后,如果认证用户成功,则签出完成。

签出完成后,因为我们的版本库中并没有任何文件,因此本的项目文件夹也是空的,此时,我们如果显示隐藏文件及文件夹

可以看到,文件夹MyObject中多了一个隐藏文件夹

.svn这个隐藏文件夹中记录着非常重要的信息,包括工作文件版本和本地副本时间等,千万记住,不要手动修改或删除,否则你本地的副本将被破坏,无法进行正常版本控制了。

3.5.2文件9种图标含义

我们在安成SVN客户端安装后,需要重启电脑或注销电脑,就会发现加入版本库的本地文件或文件夹有一个SVN专有小图标,一共有9种,以下是几种图标的含义:

绿色的勾:图标表示这是一个最新取出的工作副本,他的Subversion状态是normal。

灰色的勾:灰色图标表示”只读”,如果你给一个文件设置了svn:needs-lock属性,Subversion会让此文件只读,直到你获得文件锁。只读文件具有这个重载图标来表示你必须在编辑之前先得到一个锁。

红色感叹号:当你开始编辑一个文件,这个文件的状态就会变成modified,图标也会变成红色圆圈带一个感叹号。这样你就可以轻易的知道自从上次更新以来都有修改过哪些文件,需要提交哪些文件。

黄色感叹号:三角符号带感叹号,表示在一次update中产生了一个冲突(conflict)。

蓝色加号:意味着这个文件或文件夹已经被计划加入到版本控制之下。

红叉叉:表示相应文件或文件夹被计划删除(deleted),或者表示文件缺失。

灰色一行:表示不受版本控制,忽略版本控制。

蓝色问号:暂时还没收到版本的控制,但是没有被忽略。

锁扣:表示文件被锁定,他的Subversion状态是normal,必须先释放锁才能让别人的更改提交。

其实这个图标,我们也可以在SVN客户端设置中去更改样式,下面是SVN的几种样式,可供选择。(不得不说,SVN想的非常周到,优秀软件就该如此)

3.5.3添加文件到版本库(Add)

新文件的添加,有两种方法,一是点Add(加入)先加入到变更列表,再提交;二是直接提交,

个右键菜单分别对应加入和更新,

如果先点加入后,再提交,文件会自动选中,并且状态为增加,如果直接提交,需要手动选中该文件,如下图,点击确定,完成文件添加。

此时,我们在服务端中,点击刷新版本库,会发现已经成功加入了一个新文件。

3.5.4删除文件(Delete)

如果被删除的文件,还没有加入到版本库,则可以直接删除,如果已加入版本库,则需要通过右击文件,选中SVN中的删除

删除文件后,其父目录会有一个红色叹号,表示该目录下的文件被修改了,此时,我们需要提交一次父级目录。

3.5.5文件改名(Rename)

修改文件名,选中需要重命名的文件或文件夹,然后右键“TortoiseSVN更新文件名“,在弹出的对话框中输入新名称,点击”确定”按钮,并将修改文件名后的文件或文件夹通过“SVN提交”提交到SVN服务器上。

3.5.6还原(Revert)

还原文件或文件夹到以前的版本,如下

右击文件或文件夹,在TortoiseSvn,点击更新至版本....

打开版本更新窗口,在显示日志中选择前期版本或在版本号中输入要回退的版本号,即可。

3.5.7检查更新(Checkformodifications)

这个功能,可以看到你所做的哪些变更没有提示,包括文件或目录的增加、修改、删除等,点击检查版本库,还可以看到其他人改动的内容

3.5.8更新(SVNUpdate)

更新本地文件与SVN服务器上最新的版本一致,在需要更新的文件夹上点击右键或者在文件下空白处点击右键,选择”SVN更新”(获取指定版本中的内容,点击右键执行SVN菜单中的“更新至版本“)。

注意:这里如果你新建的文件或文件夹没有加入到Server,更新后,文件或文件夹依然存在(这也是SVN人性化的地方,求同存异,不会因为更新版本而丢失已经创建的文件)

3.5.9解决冲突文件

在更新以后,经常会有冲突文件的存在,这是因为,SVN支持不锁定更改,也就是你编辑文件的同时,别人也可以更改此文件。如果你们更新了同一文件的同一段代码。更新后,就会生成三个备份文件,并且标记冲突文件。

对于这种常有的问题,该如何解决,有两种解决方案:

1.放弃自己的更新,回滚到以前版本

2.双方协商,修改代码并提交

当然SVN也为我们提供了冲突代码比较功能

打开”与前一版本比较“,可以通过比较,来修改代码,达到一致后提交。

如果冲突代码处理不当,一方代码丢失,也不要怕,SVN仍然可以通过”更新至版本“回复丢失的内容。

3.5.10显示日志(Showlog)

右击SVN菜单中选择”显示日志“可以查看谁在什么时候做了哪些操作。

3.5.11版本浏览器(Repo-browser)

右击SVN菜单中选择”版本浏览器“,输入URL地址,未登录的需要验证用户,在此可以看到其他人对该版本的操作情况,比如锁定等操作。

未完待下篇继续……

3.6本节要点

本节主要介绍了一个非常优秀并且使用人数较多的源代码版本控制工具SVN(全名:TortoiseSVN),它的使用场景适用于几十人的中小型开发团队,具有跨平台(HTTP方式访问)、跨地区、轻量级等众多优点。

(转)SVN详解的更多相关文章

  1. webstorm配置svn详解

    1. 打开webstorm-> file -> setting -> plguins 输入svn如果没有SVNToolBox就在下面的列表中安装SVNToolBox插件即可. 2.c ...

  2. svn详解和使用

    2 svn介绍 2.1 项目管理中的版本控制问题 通常软件开发由多人协作开发,如果对代码文件.配置文件.文档等没有进行版本控制,将会出现很多问题: > 备份多个版本,占用磁盘空间大> 解决 ...

  3. iOS开发——开发实战篇&版本控制SVN和Git使用详解

     版本控制SVN和Git使用详解     公司的实际开发中,在天朝使用较多的还是SVN,因为SVN是集中式的,在天朝上班你们都懂的!     -----------------svn--------- ...

  4. SVN组成中trunk,branches and tags功能用法详解

    SVN组成中trunk,branches and tags功能用法详解  我相信初学开发在SVN作为版本管理时,都估计没可能考虑到如何灵活的运用SVN来管理开发代码的版本,下面我就摘录一篇文章来简单说 ...

  5. SVN与TortoiseSVN实战:文件加锁详解

    硬广:<SVN与TortoiseSVN实战>系列已经写了八篇,本篇是完结篇,整个系列结合TortoiseSVN对SVN中容易被忽视的部分进行了详解,以技巧性为主. 本篇详解使用Tortoi ...

  6. SVN与TortoiseSVN实战:补丁详解

    硬广:<SVN与TortoiseSVN实战>系列已经写了五篇,第二篇<SVN与TortoiseSVN实战:标签与分支>和第三篇<SVN与TortoiseSVN实战:Tor ...

  7. SVN功能详解

    SVN功能详解   TortoiseSVN是windows下其中一个非常优秀的SVN客户端工具.通过使用它,我们可以可视化的管理我们的版本库.不过由于它只是一个客户端,所以它不能对版本库进行权限管理. ...

  8. SVN中tag branch trunk用法详解

    SVN中tag branch trunk用法详解 2010-05-24 18:32 佚名 字号:T | T 本文向大家简单介绍一下SVN中tag branch trunk用法,SVN中tag bran ...

  9. SVN与TortoiseSVN实战:补丁详解(转)

    硬广:<SVN与TortoiseSVN实战>系列已经写了五篇,第二篇<SVN与TortoiseSVN实战:标签与分支>和第三篇<SVN与TortoiseSVN实战:Tor ...

随机推荐

  1. Aptana Studio 快捷键

    窗口 Ctrl+ Shift +L 调出快捷键提示 Ctrl+ W 关闭当前标签窗口 Ctrl+ Shift + W 关闭当前标签窗口 Ctrl+ F6 (或者是Aptana的Ctrl+Tab )下一 ...

  2. DNS解析原理

    1.在浏览器中输入www.qq.com域名,操作系统会先检查自己本地的hosts文件是否有这个网址映射关系,如果有,就先调用这个IP地址映射,完成域名解析. 2.如果hosts里没有这个域名的映射,则 ...

  3. css()和 attr()的区别

  4. MATLAB文件操作及读txt文件

    转自:http://blog.csdn.net/vblittleboy/article/details/8049748 文件操作是一种重要的输入输出方式,即从数据文件读取数据或将结果写入数据文件.MA ...

  5. 简单又强大的联发科手机PhilZ Touch Recovery安装器,详细教程 - 本文出自高州吧

    原文地址:http://bbs.gaozhouba.com/thread-19355-1-1.html * * * * * * * * * * * * * * * * * * * * * * * * ...

  6. Qt 窗体布局 good

    布局相关对象及简介 窗体上的所有的控件必须有一个合适的尺寸和位置.Qt提供了一些类负责排列窗体上的控件,主要有:QHBoxLayout,QVBoxLayout,QGridLayout,QStackLa ...

  7. Tag标签系统设计

    转一篇关于tag的文章:  <Tagging: People-powered Metadata for the Social Web>出版于2008年,中文版译为<标签:标记系统设计 ...

  8. POJ1321 棋盘问题(dfs)

    题目链接. 分析: 用 dfs 一行一行的搜索,col记录当前列是否已经放置. AC代码如下: #include <iostream> #include <cstdio> #i ...

  9. UVA11388 GCD LCM(数论)

    题目链接. 题意: 给定两个数,一个G,一个L,找出两个数a,b(a<=b),使得这两个数的最大公约数为G,最小公倍数为L,且(a最小). 分析: 当a,b存在时,a一定为G. 自己证了一下,数 ...

  10. MySQL通用批量写入工具(Python)

    背景   平台目前的分析任务主要以Hive为主,分析后的结果存储在HDFS,用户通过REST API或者Rsync的方式获取分析结果,这样的方式带来以下几个问题:   (1)任务执行结束时间未知,用户 ...