TortoiseSVN 和 VisualSVN Server 使用教程

来源 https://blog.csdn.net/xgf415/article/details/75196360

目录:

SVN 是什么?

TortoiseSVN 和 VisualSVN Server 安装

创建版本库、用户

检出

更新与提交

历史信息与版本回退

解决冲突

1. SVN 是什么?

SVN 是 Apache Subversion 的缩写,是一个开放源代码的版本控制系。这些数据放置在一个中央资料档案库(repository) 中。 这个档案库很像一个普通的文件服务器,不过它会记住每一次文件的变动。 这样你就可以把档案恢复到旧的版本,或是浏览文件的变动历史。

SVN 一些概念

repository(版本库):文件统一存放的地方。

checkout(检出):当你手上没有源文件的时候,你需要从repository 提取一份。

commit(提交):当你已经修改了文件,你就需要Commit到repository。

update (更新):当你已经Checkout了一份文件,Update一下,你的文件就会与服务器同步。

2. TortoiseSVN 和 VisualSVN Server 安装

SVN 可以和 VisualSVN Server 一起使用。VisualSVN Server 是一个集成的 svn 服务端工具,可以对 SVN 的版本库、用户、组、权限等进行管理。 TortoiseSVN 和 VisualSVN Server 安装比较简单。

VisualSVN Server 下载地址:https://www.visualsvn.com/server/download/

SVN 的中文包下载地址:https://tortoisesvn.net/downloads.html

设置中文

上面三个安装完成之后,右键 -> TortoiseSVN -> Settings,设置 language 为中文即可。

3. 创建版本库、用户、组

开始菜单中找到 VisualSVN Server ,打开 VisualSVN Server Manbger

创建版本库

设置好版本库类型、名称、权限之后,一个版本库就创建好了。

创建用户

右键 Users -> Create User,设置好用户名和密码。

创建组

右键 Groups -> Create Group,设置组名, 并添加用户。

设置版本库的用户、组及其权限

为了对不同用户、组设置不同的权限,我又创建了另外两个用户、两个组。选择 test 版本库, 右键 Priperties,添加用户、组, 并设置其读写权限。

manager(管理) 组读写权限,包含一个用户 root;develop(开发)组读写权限,包含一个用户 dev;visitor (访问)只读权限,包含一个用户 visit。

4. 检出

复制检出路径:选择 test ,右键 Copy URL to Clipboard

新建一个空文件夹,右键 SVNCheckout,粘贴刚刚复制的检出路径。

确定之后,会弹出验证框,输入刚刚创建的用户和密码,确认之后检出完成。

5. 更新与提交

更新与提交一般流程:

加入文件

新建一个文件,选择该文件,右键 TortoiseSVN -> 加入

检查修改

右键 TortoiseSVN -> 检查修改

更新

右键 更新(Update)

冲突:如果其他人在你提交之前提交到了服务器,更新之后可能就会发生冲突。

提交

右键 提交(Commit)

提交完成。

这次先加入一个文件 file.txt,再修改 readme.txt 文件的内容。然后进行检查修改、更新和提交。

撤销修改

在未提交之前,如果作了修改,但是想撤销一些修改。假设修改 readme.txt 的内容,同时增加一个文件 file.txt。现在想撤销一些修改,右键 TortoiseSVN -> SVN 还原。

6. 历史信息与版本回退

查看历史

右键 TortoiseSVN -> 显示日志

版本回退

右键 TortoiseSVN -> 更新至版本

7. 解决冲突

冲突类型

  • 内容冲突:当两名(或更多)开发人员修改了同一个文件中相邻或相同的行时就会发生文件冲突。
  • 树冲突:当一名开发人员移动、重命名、删除一个文件或文件夹,而另一名开发人员也对它们进行了移动、重命名、删除或者仅仅是修改时就会发生树冲突。

SVN 树冲突类型和解决方法有点复杂, 可以参考这篇博客。

解决方法

  1. 根据冲突内容,手动修改文件内容。
  2. 执行命令 TortoiseSVN ->已解决,然后提交修改到版本库。

现在我们用另外一个用户 dev 来登陆 SVN, 并修改 readme 的内容,然后提交。当 root 用户也修改了 readme 的内容,更新时就可能发生冲突。

右键 TortoiseSVN -> 检查修改

修改冲突的方法:

用左边的内容;

用右边的内容;

先用左边再用右边的内容;

先用右边再用左边的内容;

注意:每个冲突行都要使用上面的方法处理一次。

现在我们使用先用左边再用右边的内容进行处理:

保存之后关闭,右键 TortoiseSVN -> 已解决的

确定,冲突解决,然后提交。

=================================== End

TortoiseSVN 和 VisualSVN Server 使用教程的更多相关文章

  1. (转)TortoiseSVN与VisualSVN Server搭建SVN版本控制系统

    本片主要介绍如何搭建SVN版本控制系统,主要使用工具: 1 客户端:TortoiseSVN (小乌龟) 2 服务端:VisualSVN Server 搭建出图形化管理,以及右键菜单版本控制管理的SVN ...

  2. TortoiseSVN与VisualSVN Server搭建SVN版本控制系统

    本片主要介绍如何搭建SVN版本控制系统,主要使用工具: 1 客户端:TortoiseSVN (小乌龟) 2 服务端:VisualSVN Server 搭建出图形化管理,以及右键菜单版本控制管理的SVN ...

  3. Windows平台下结合 tortoiseSVN 和 VisualSVN Server 搭建SVN服务器并实现 web 站点同步

    1. tortoiseSVN 关于 tortoiseSVN 的安装使用详见博文 TortoiseSVN的安装及其简单使用. 2. VisualSVN Server 关于 VisualSVN Serve ...

  4. TortoiseSVN与VisualSVN Server搭建SVN版本控制系统【转】

    转自:http://www.cnblogs.com/xing901022/p/4399382.html 本片主要介绍如何搭建SVN版本控制系统,主要使用工具: 1 客户端:TortoiseSVN (小 ...

  5. TortoiseSVN与VisualSVN Server搭建SVN版本控制系统(转)

    地址:http://www.cnblogs.com/xing901022/p/4399382.html

  6. windows安装VisualSVN Server

  7. 项目管理实践教程二、源代码控制【Source Control Using VisualSVN Server and TortoiseSVN】

    在第一篇文章 项目管理实践教程一.工欲善其事,必先利其器[Basic Tools]发布后,根据大家的回复,我需要向大家说明几个问题: 1.为什么要用VisualSVN Server,而不用Subver ...

  8. VisualSVN Server以及TortoiseSVN客户端的配置和使用方法

    http://www.cnblogs.com/beautifulFuture/archive/2014/07/01/3818211.html 近期学习代码管理工具,首先学习一下svn和Tortoise ...

  9. SVN--下载、安装VisualSVN server 服务端和 TortoiseSVN客户端

    前言: 在http://www.cnblogs.com/xiaobaihome/archive/2012/03/20/2407610.html的博客中已经很详细地介绍了SVN的服务器--VisualS ...

随机推荐

  1. OpenStack入门篇(八)之镜像服务Glance

    一.Glance的概述 Glance是为虚拟机的创建提供镜像的服务,我们基于Openstack是构建基本的IaaS平台对外提供虚拟机,而虚拟机在创建时必须为选择需要安装的操作系统,Glance服务就是 ...

  2. centOS上安装最新git 2.4.0

    git 地址: https://www.kernel.org/pub/software/scm/git/ 1.  先安装一堆依赖 yum install curl curl-devel zlib-de ...

  3. php常用的几个预定义变量

    __FILE__:返回所在路径文件名和文件名称 __DIR__:返回文件所在的完整目录 __LINE__:返回当前文件代码的行号 __CLASS__:返回当前类名 __FUNCTION__:返回当前方 ...

  4. 第五章Web应用与应用层协议

    Web应用与应用层协议 本篇博文中的主要参考文献是<计算机网络高级教程>,分别是吴功宜老先生和吴英教授合著.这部教程是我研究生老师所推荐的网络必读科目,由于该教程讲解的基础知识详细,但内容 ...

  5. 【python 3.6】如何将list存入txt后,再读出list

    今天遇到一个需求,就是将一个list文件读取后,存入一个txt配置文件.存入时,发现list文件无法直接存入,必须转为str模式. 但在读取txt时,就无法恢复成list类型来读取了(准确地说,即使强 ...

  6. Linux内核学习笔记(5)-- 进程调度概述

    进程调度程序是多任务操作系统的基础,它是确保进程能有效工作的一个内核子系统,负责决定哪个进程投入运行.何时运行以及运行多长时间.只有通过进程调度程序的合理调度,系统资源才能够最大限度地发挥作用,多进程 ...

  7. 第二次ScrumMeeting博客

    第二次ScrumMeeting博客 本次会议于10月26日(四)22时整在3公寓725房间召开,持续15分钟. 与会人员:刘畅.方科栋.辛德泰.窦鑫泽.张安澜. 1. 每个人的工作(有Issue的内容 ...

  8. xpath抓取的值有\r\n\t时,去掉的方法

    解决办法: normalize-space() 例子: 原来的xpath为: user=selector.xpath('//*[@id="Con"]/tr[1]/th/text() ...

  9. request.quest/query_string/params/body等方法介绍

    假设url:http://192.168.1.111:8080/api/cluster/group?wzd=111&abc=cc 方法类型:POST,body是{"name" ...

  10. 【IdentityServer4文档】- 启动和概览

    启动和概览 有两种基本的方式来启动一个新的 IdentityServer 项目: 从空项目开始(从头开始) 从 Visual Studio 的 ASP.NET Identity 模板开始 假如您从头开 ...