从刚刚参加工作就开始使用svn,清晰的记得那年师姐比较生气的来找我:“你怎么又不更新就提交代码了,把我写的都给覆盖掉了”,哈哈~

  虽然一直在用svn,不过在日常工作中主要用到的是简单的操作,而且大多数是基于eclipse插件、客户端小乌龟直接操作的。对于svn的理解还是比较单一的。当然目前除了集中式版本管理工具svn之外,比较火的还有分布式的版本管理工具git。

  下面借着学习svnkit的机会,把svn也学习一遍,加深了解~

  官网简单介绍:

    官网:http://subversion.apache.org/

    所属机构:Apache开源组织。

    特性:集中式版本管理工具。

    开发:svn本身是使用c语言开发的。

    版本:目前最高的是1.9版本,1.10版本还在开发中,在即将到来的2017年可能会发布。

    版本支持:官方对于1.7和更老的版本不予以支持,1.8版本予以部分支持,1.9版本予以完全支持。

    相关性:客户端工具TortoiseSVN、IDE插件(Eclipse、Netbeans、IntelliJ IDEA等)、java实现svnkit

  接下来我们照着官方的例子做一个简单的入门:1.创建仓库  2.将工程交由版本库控制  3.重新检出工程

  官网示例链接:http://svnbook.red-bean.com/nightly/en/svn.intro.quickstart.html

  准备工作:下载一个VisualSVN Server(和Subversion一样是一个服务端管理的软件),这里我随便在百度下了一个:VisualSVN Server 3.5.6

  已知信息:①.VisualSVN Server安装目录:E:\VisualSVN\Repositories,使用VisualSVN新建或从其他目录导入repository,均会在此目录下创建repository。

       ②.工程目录(projectA):E:\SVN\workProejcts\projectA

  需求:假定我们有一个工程:projectA,现在想使用我们刚刚建立的仓库来管理projectA。

  SVN官方比较期望我们工程的目录结构如下,当然我们也可以不按照这个目录结构来:

  project - branches

         - tags

         - trunk - 项目文件A

             - 项目文件B

  对于这三个目录,官方没有给出明确的用法,大家可以根据习惯使用,如:

  trunk:开发主目录,主线。

  branches:分支开发目录。

  tags:只读打包目录。

  好了扯远了,回归主题~我们姑且按照官方的标准来。

  使用svn命令行操作:

  1.在VisualSVN Server目录下创建一个仓库:svnadmin create E:\SVN\svnRepositories\myRepository

  执行后,cd进去ls一下,如下图:

  

  使用VisualSVN Server查看此仓库URL(SVN Repository URL):https://wangdaye-PC/svn/myRepository/

  2.将工程交由版本库控制:svn import 项目目录 SVN Repository URL -m "提交日志信息"

  svn import E:\SVN\workProejcts\projectA https://wangdaye-PC/svn/myRepository/ -m "initial import"

  我们可能会遇到没有权限的问题:

  

  没关系,使用VisualSVN Server添加一个用户,并为此仓库添加用户的访问权限即可:

  

  权限操作成功后,再次执行命令,操作成功:

  

  至此,我们发现本地磁盘中的projectA实际并未收到仓库的版本控制!因为我们在projectA的目录下并未看到.svn的隐藏文件。怎么办呢?

  3.检出工程:svn checkout SVN仓库URL 任意本地磁盘工作目录

  svn checkout https://wangdaye-PC/svn/myRepository/trunk E:\SVN\svnWorkSpace\projectA

  

  至此,我们执行成功了,查看磁盘目录,受到版本控制了,我们第二步导入的projectA可以删掉了。

  

  OK,大功告成~

  

 

SVN学习——简单入门之创建仓库、导入、检出(一)的更多相关文章

  1. Django学习系列3:创建仓库

    在创建仓库之前,在项目superlists中新建一个Python文件,命名为functional_tests.py,里面的内容如下: # File: functional_test.py # Auth ...

  2. 【Git/GitHub学习笔记】基本操作——创建仓库,本地、远程同步等

    近日想分享一些文件,但是用度盘又太麻烦了(速度也很恶心).所以突发奇想去研究了下GitHub的仓库,这篇文章也就是一个最最最基础的基本操作.基本实现了可以在GitHub上存储文本信息与代码. 由于我的 ...

  3. github入门之创建仓库--3

    1.登陆到github,点击加号中的New repository 2.设置仓库信息 *注: ------Description:添加仓库说明,不是必填项 ------Public.Private:选择 ...

  4. MacOS SVN简单入门

    背景:MacOS内置了SVN的客户端和服务器端的软件,下边所使用到的目录需要结合自己电脑的具体情况进行设置,并不是很困难. MacOS SVN简单入门 第一部分,创建本地的SVN测试仓库,并修改相应的 ...

  5. 版本管理工具SVN学习(一):简单的SVN命令,兼对比Git

    新公司用SVN来管理代码,而且公司自己搭建了SVN服务器,所以要学习下SVN的相关命令.服务器搭建等技能知识.上家公司是用Git管理代码,而且代码托管在git@oschina上,自然不用操心Git服务 ...

  6. svn学习总结

    安装svn subversion服务参考博客http://huihai.iteye.com/blog/1985238 一:svn版本管理的作用 a:备份程序   项目开发过程中,防止不可控因素造成的资 ...

  7. SVN学习---使用 Visual SVN 搭建SVN服务器

    1.1. 使用 Visual SVN 搭建SVN服务器 搭建纯粹SVN服务器 --- svn:// 访问资源 将SVN 和 Apache服务器整合 ,搭建web SVN服务器 ----  https: ...

  8. SVN无法检出项目

    情况说明: SVN的管理员给我一个项目的检出权限,我用浏览器可以访问,TortoiseSVN无法检出,提示没有访问URL的权限,不能检出. SVN管理员交流别人可以使用,我用同事的电脑,使用我的账号检 ...

  9. svn学习笔记(1)入门学习----安装及创建运行仓库

    学习及使用svn有一段时间了,但是以前学习的时候不怎么用,现在用只是简单的更新上传,又把基本理论忘了.为了以后自己看自己的笔记回忆,特此记录 svn学习博客:http://www.cnblogs.co ...

随机推荐

  1. windows cmd下创建虚拟环境virtualenv

    一:虚拟环境virtualenv 如果在一台电脑上, 想开发多个不同的项目, 需要用到同一个包的不同版本, 如果使用上面的命令, 在同一个目录下安装或者更新, 新版本会覆盖以前的版本, 其它的项目就无 ...

  2. day--39-MySQL的多表查询

    多表查询一:表的基本介绍 可以参考:https://www.cnblogs.com/cdf-opensource-007/p/6517627.html 建立一个员工表信息表和一个部门表,每个员工都对应 ...

  3. C++_类继承7-类设计回顾

    编译器生成的成员函数 编译器会自动生成一些公有的成员函数——特殊成员函数. 1. 默认构造函数 提供构造函数的动机之一是确保对象总能被正确地初始化.如果类包含指针成员,则必须初始化这些成员.最好提供一 ...

  4. 打开页面时就提交,可以做一些自动登陆 还有SICLOGIN的测试代码

      <HTML> <head> <title> Untitled Document</title > (1)自动提交表单: <meta http- ...

  5. VS2015打开特定项目就崩溃

    今天在打开之前写的项目的时候,一开vs就崩溃关闭了,打开其他项目的.sln和.vsproj就可以,唯独有1个项目打不开,也不知道为啥,气死了. 去网上找到的解决办法: 步骤1:开始–>所有程序– ...

  6. Python BeautifulSoup库的用法

    BeautifulSoup是一个可以从HTML或者XML文件中提取数据的Python库,它通过解析器把文档解析为利于人们理解的文档导航模式,有利于查找和修改文档. BeautifulSoup3目前已经 ...

  7. esper(4-3)-Non-Overlapping Context

    语法 create context context_name start start_condition end end_condition 如: // 9点到17点此context才可用(以引擎的时 ...

  8. vue中使用对非表单元素使用contenteditable的问题

    先说下问题,再上解决方案: span编辑时有多余空格和回车会影响样式(我用的是span便以此为例) 代码:(有换行符) 效果图: 代码:(无换行符) 效果图: 当在span标签的contentedit ...

  9. easyUI--datagrid 实现按键控制( enter tab 方向键 )

    1.表格定义时加上 onClickCell: onClickCell,2.定义列时加入编辑器3.引入 key.js 即可使用 enter 键 或者向下箭头 选中单元格下移 选中单元格上移 tab键 选 ...

  10. 第十三章:基于socket.io实现即时通信

    安装好环境,请参考ionic环境搭建之windows篇 和 ionic环境搭建之OS X篇 . 服务器端的搭建参考socket io官网,里面有非常详细的描述,按照步骤下来,最终可以在localhos ...