SVN是Subversion的简称,是一个开放源代码的版本控制系统,相较于CVS,它采用了分支管理系统,它的设计目标就是取代CVS

为什么需要SVN

通常软件开发由多人协作开发,如果对代码文件、配置文件、文档等没有进行版本控制,将会出现很多问题:

  • 备份多个版本,占用磁盘空间大
  • 解决代码冲突困难
  • 容易引发BUG
  • 难于追溯问题代码的修改人和修改时间
  • 难于恢复至以前正确版本
  • 无法进行权限控制
  • 项目版本发布困难

所以我们需要使用版本控制工具,SVN的作用正是在于多人协作,版本回退等等问题上。SVN的使用较为简单,而且可以跨平台使用,属于C/S结构的软件,需要客户端和服务器端,一般来说应该是一台服务器或电脑作为服务器端,我们在服务器端中建立仓库,但是为了学习方便我们在本机即模仿客户端又模仿服务器端。

客户端下载地址:https://tortoisesvn.net/downloads.html

服务器端下载地址:https://www.visualsvn.com/downloads/

服务器端安装

基本上和安装一般软件一样,一路next即可,但是需要注意以下几点:

这个端口号默认使用443,也可以使用8443这个备用端口号

如果两个端口都有冲突,我们可以找到端口是哪个程序,把程序进程停止

在CMD中使用命令:

找到占用端口的程序的PID : 

我们在任务管理器,找到pid值,停止掉就行了

我们的Tomcat也可以使用该方法解决8080占用的问题

如何知道服务器端安装好了?

如果安装好了,我们可以在系统 —> 服务中可以找到SVN  或者是在CMD中使用命令:

svnadmin --version

就会显示svn服务器的版本

客户端的安装

客户端的安装没什么值得说明的,一路next,需要说明的是该客户端有中文语言包哦,就在其下载页就可以找到。语言包的安装也是一路next,它会自动找到客户端的安装位置,不需要我们来指点,很简单,然后我们在客户单中setting选择中文即可:

如何知道客户端安装好了?

只要鼠标右键出现:

使用命令操作SVN

1. 首先我们需要建立仓库,在CMD中使用命令:

svnadmin create 仓库位置

如: svnadmin create D:\webApp

2. 还需要将SVN服务器关联到这个仓库,命令:

svnserve -d -r 仓库地址

-d 表示svn服务在后台运行, -r指明仓库地址,注意这是黑窗口的光标会移到下一行并不停的闪烁,就表示成功的开启SVN服务,我们不要关闭这个黑窗口哦

注意:命令是svnserve

接下来我们就可以开始同步仓库中的东西了,现在相当于同步空仓库中的东西,在另一个文件夹中,在使用同步工作吧

同步仓库

1. 默认SVN是不允许匿名用户访问仓库的,所以我们需要将这个仓库的conf/svnserve.conf 文件的第19行修改为write,一点要是19行

2. 第一次同步需要先检出(checkout)

在文件夹中右键检出,会出现需要我们输入仓库地址的地方:

因为我们之前已经将仓库与SVN客户端关联,所以我们要使用: svn://localhost 这个地址即可,如果不再同一台机器上,把localhost改为ip地址

检出成功之后,可以在这个文件夹中看到一个隐藏的.svn文件夹

因为是一个空仓库,所以没有什么文件存在,我们可以新建一个文件,右键SVN提交

提交的时候,需要我们填写一些提交信息和选中要提交的文件,其实提交信息写不写都可以,但是强烈推荐写上提交信息,因为正是这些信息帮助我们选择回退的版本。

3. 其他同步该仓库的用户就需要SVN更新,更新之后就可以得到这个新建的文件

注:SVN提交(commit) SVN更新(update)都是在文件夹的空白位置鼠标右键可以看到的

SVN中的图标

我们在使用SVN管理代码的时候,文件会出现一些图标,来认识一下常见的图标吧

需要说明的是,但当发生代码冲突的时候,叹号图标并不会立即出现,存在延迟,所以我们还是以错误信息为准吧

忽略某个文件或是某类文件

我们在需要忽略的文件上右键,可以选择忽略,或者或略该文件类型的文件,或者对于文件夹可以递归的忽略

回退版本

回退版本的依据就是我们之前提交的提交信息,根据这些日志信息,我们可以准确的知道需要回退到哪个版本,所以还是建议每次提交都写上提交信息

使用图形界面创建仓库和用户

终于要使用图形界面了,我们安装的SVN服务器端支持图形界面的:

创建仓库和用户都是很简单的,重点在于为用户分配权限:

可以给不同用户分配读写权限

我们还可以在浏览器中浏览我们仓库信息

在Eclipse中配置SVN插件

在Eclipse的安装目录中dropins下新建一个SVN文件夹,在里面放入SVN插件的文件,重启Eclipse即可

检验是否安装成功

出现SVN的视图就表示安装成功了

发布项目到svn(add到svn)

第一步 右键点击项目 team—share project

第二步 选择使用版本控制工具

第三步 创建仓库位置

输入仓库路径

第四步 点击finish进行把项目add到svn上

(1)输入用户名和密码,可以把勾上,以后就不用每次都输入了

(2)在项目上有图标变化,右键点击项目,点击team-提交

点击ok

图标变成圆柱的图标,表示发布完成

从svn服务器下载项目(checkout)

第一步 打开svn资源库,没打开的话,就在view中找到打开

(1)添加svn资源库

(2)输入仓库路径

第二步 右键点击要下载项目,点击 检出为

点击finish完成

处理版本冲突

冲突的表现为我们后修改的代码提交不上:

版本冲突的问题难以避免,我们可以在选择统一的时间来提交,专门的人员来处理代码冲突。

但是我们遇见了应该怎么办呢?

1. 先备份我们写的代码

2. 同步更新代码,也就是SVNupdate操作

3.  将多余的.mine .r6 .r7(这两的文件不一定是这两个文件后缀) 删除,留下代码冲突文件再修改,之后再提交即可

SVN的学习的更多相关文章

  1. SVN的学习和安装

    SVN分为服务器版本和客户端版本 服务器:VISUALSVN SERVER https://www.visualsvn.com/server/download/ 安装和配置(都很简单,只要不断的下一步 ...

  2. SVN的学习以及使用!

    什么是版本控制? 版本控制是记录一个或若干文件内容变化的系统.以便将来查阅特定版本修订情况. 版本控制,就像是一本历史书,记录了软件版本的迭代过程. 为什么需要"版本控制" 需要清 ...

  3. Git 与 SVN 命令学习笔记

    一:Git git config --global user.name "you name"   #设置用户名git config --global user.email &quo ...

  4. Mac svn使用学习-3-客户端调用服务端简单例子

    既然在前一篇内容中我们已经讲svn服务器搭建好了,那么接下来我们试着试着简单使用一个该服务器 1.从本地导入代码到服务器上 userdeMBP:~ user$ svn import /Users/us ...

  5. Mac svn使用学习-2-服务端

    2.在mac环境下搭建一个SVN服务器环境 1)创建一个名为myCode的仓库——svnadmin命令 格式: svnadmin SUBCOMMAND REPOS_PATH [ARGS & O ...

  6. Mac svn使用学习-1-简介

    在Windows环境中,可以使用TortoiseSVN来搭建svn环境.但是由于Mac自带了svn的服务器端和客户端功能,因此可以直接使用svn功能. svn即subversion,Subversio ...

  7. Mac svn使用学习-4-客户端cli命令详解

    客户端cli的使用 WC:Working Copy 你的工作区 将文件或目录版本化,这样下一次提交到存储库的时候,他们就都会被提交上去.能实现版本化的命令有: add 1.import 是否访问存储库 ...

  8. SVN 使用学习记录

    一.基本SVN操作 安装了SVN之后,在本机上点击右键,就能够看到如下信息: 1.建立SVN Repository 下面来建立一个SVN Repository.这个文件夹是同步用的,你可以放在本机的任 ...

  9. SVN学习——简单入门之创建仓库、导入、检出(一)

    从刚刚参加工作就开始使用svn,清晰的记得那年师姐比较生气的来找我:“你怎么又不更新就提交代码了,把我写的都给覆盖掉了”,哈哈~ 虽然一直在用svn,不过在日常工作中主要用到的是简单的操作,而且大多数 ...

随机推荐

  1. ASP.NET MVC 中使用用户控件——转

    讲讲怎么在 ASP.NET MVC2中使用用户控件.首先我们新建一个用户控件,   我们命名为SelectGroup.ascx,代码如下 <%@ Control Language="C ...

  2. strip()函数和 split()函数

    一:python strip()函数介绍 函数原型:strip可以删除字符串的某些字符 声明:s为字符串,rm为要删除的字符序列 s.strip(rm)        删除s字符串中开头.结尾处,位于 ...

  3. js 由快到慢的执行

    let t=0; for(var i=0;i<len;i++){ (function (t) { $timeout(function(){ console.log(t); },t); })(t) ...

  4. 关于HslCommunication组件的双模式客户端的说明,此说明适用于所有的派生类客户端,包括三菱,西门子,欧姆龙,modbustcp,机器人,simplifyNet客户端等等

    前言 本文主要是答疑文章,针对广大网友非常频繁的提问而总结的问题 nuget地址:https://www.nuget.org/packages/HslCommunication/            ...

  5. QUnit使用

    什么是单元测试 每个单元测试就是一段用于测试一个模块或接口是否能达到预期结果的代码. QUnitjs 概念Qunit是一款强大的用于帮助调试代码的,JavaScript单元测试框架.是jQuery的官 ...

  6. Android 编程 高德地图 (实现显示地图以及定位功能)

    本文参考文章: http://www.apkbus.com/blog-904057-63610.html 本人实现的 定位代码:(具体配置省略,可见参考文章) package com.example. ...

  7. 【剑指offer】11--旋转数组的最小数字(二分查找)

    原创博文,转载请注明出处! # 本文是牛客网<剑指offer>刷题笔记 1.题目 旋转数组的最小数字:输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素. 例如数组{3,4,5,1 ...

  8. [转载][QT][SQL]sql学习记录4_sqlite约束

    转载自:定义以及示例请见 : http://www.runoob.com/sqlite/sqlite-constraints.html SQLite 约束 约束是在表的数据列上强制执行的规则.这些是用 ...

  9. 利用ajax完成项目图册上传删除【实际项目】

    [项目页面效果] [前台jsp页面] jsp的js代码 <script type="text/javascript"> //上传项目图片 function upload ...

  10. Uoj 129 寿司晚宴

    Uoj 129 寿司晚宴 显然合法性只与每个数所含的质因子有关,考虑状压 \(dp\) 若记录所有质因子状态显然爆炸,注意到每个数最多有一个超过 \(\sqrt 500\) 的大质因子,而其他的小质因 ...