SVN版本控制说明与相关指令
SVN版本控制说明
目的
多个版本中并行开发,提高开发效率;
保证各个版本和各个环境(开发、测试、主干)的独立,避免相互影响;
通过分支与主干的合并,这样主干永远是最新、最高版本,并且都在后面的测试中,保证了质量;
用分支进行bug修改,而主干上进行新功能的开发。分支上的bug修改完合并到主干上;
SVN目录结构

Trunk(开发库) :
主干目录,负责新功能的开发;
此目录下的文件为基准文件,放置稳定代码的主要环境;
开发人员日常开发的工作区,由开发者所控制;
Branches(受控库) :
测试版本代码存放的地方,需要开发组长提交测试申请修改;
用于开发的分支目录,修正当前发布版本的bug,与此同时主干上的开发正常进行,两边互不干扰;
当一个branch完成了,并且认为它足够稳定的时候,它必须合并回trunk;
Tags(产品库) :
存放基线库、发布版,是测试通过版本存放的地方;
基线,就是给版本建立一个映像(或着叫快照),并不占用服务器物理磁盘;
这个文件夹下的内容通常只有配置管理员可以修改,其他人只读;
分支
分支是给源项目创建副本,让每个工作组在各自的副本上进行开发,最后再将各个工作组的副本合并到源项目中。在此,各个副本被称作分支(branches),源项目被称为主干(trunk);
分支不是复制版本内容,而是做一个内部的引用,对服务器也没有空间上的开销;
分支定义规则
project name + 日期时间 + 版本号,比如:project_20150202_v1.0.3,在创建每一个分支时,必须增加标注。
mac 终端创建svn分支
svn 文件夹结构
+trunk/ (freeze)
+branches/
+tags/
创建分支
svn cp -m "create branch" http://svn_server/xxx_repository/trunk http://svn_server/xxx_repository/branches/br_(分支名称)
获得分支cd 到branches目录然后
svn co http://svn_server/xxx_repository/branches/br_(分支名称)
checkout 出来后如果本地没有就update下 ,或者可能svn慢了,可以关掉重新开启,然后更新下。
合并主干上的最新代码到分支上
cd 到分支名称的文件夹下面
svn merge http://svn_server/xxx_repository/trunk
分支合并到主干
cd trunk (主线)
svn merge --reintegrate http://svn_server/xxx_repository/branches/br_(分支名称)
分支合并到主干中完成后应当删该分支,因为在SVN中该分支已经不能进行刷新也不能合并到主干。
合并版本并将合并后的结果应用到现有的分支上
svn -r 148:149 merge http://svn_server/xxx_repository/trunk
建立tags
产品开发已经基本完成,并且通过很严格的测试,这时候我们就想发布给客户使用,发布我们的1.0版本
svn copy http://svn_server/xxx_repository/trunk http://svn_server/xxx_repository/tags/release-1.0 -m "1.0 released"
备注:如果不知道svn url 是多少 可以利用svn info 中查看。感觉还是终端操作比较好用。其他的checkout的时候经常会卡住。如果出现checkout卡在一个文件的情况下可以用终端co 试试
查看svn 有几个分支svn ls 分支地址 --verbose
参考文章:https://blog.csdn.net/maxracer/article/details/5338954
SVN版本控制说明与相关指令的更多相关文章
- SVN版本控制工具使用学习
		SVN版本控制工具使用学习 Subversion是优秀的版本控制工具. 1.下载和搭建SVN服务器 http://subversion.apache.org/packages.html 类型有5种,推 ... 
- AnjularJS系列2 —— 表单控件功能相关指令
		第二篇,表单控件功能相关指令. ng-checked控制radio和checkbox的选中状态 ng-selected控制下拉框的选中状态 ng-disabled控制失效状态 ng-multiple控 ... 
- 快速清除文件夹svn版本控制信息
		将下面内容另存为clear.bat文件,在有版本控制的目录执行即可 @echo On @Rem 清除SVN版本控制信息 @for /r . %%a in (.) do @if exist " ... 
- Linux相关指令
		Linux相关指令 1.find文件搜索功能 find [目录列表] [匹配参数] [匹配标准] -name :按文件名称进行搜索 -group :按文件所属组进行搜索 -user :按文件拥有者进行 ... 
- 取消svn版本控制
		删除项目中的版本控制,即删除项目文件夹下的所有.svn文件夹(在做项目的时候,有时候想把项目拷回去看看,但是文件太大了,而且压缩起来很慢.这主要是因为在项目中有大量的.svn文件夹.所以才想把.svn ... 
- 基于腾讯Centos7云服务器搭建SVN版本控制库
		基于腾讯Centos7云服务器搭建SVN版本控制库 最近在和小伙伴组队参加一个关于人工智能的比赛,无奈不知道怎么处理好每个人的代码托管问题,于是找到了晚上免费svn托管服务器的服务,但是所给的免费空间 ... 
- Linux指令--性能监控和优化命令相关指令
		原文出处:http://www.cnblogs.com/peida/archive/2012/12/05/2803591.html.感谢作者无私分享 性能监控和优化命令相关指令有:top,free,v ... 
- 常见压缩格式分析,及 Linux 下的压缩相关指令
		可先浏览加粗部分 一.常见压缩档 *.zip | zip 程式壓縮打包的檔案: (很常见,但是因为不包含文件名编码信息,跨平台可能会乱码) *.rar | winrar 程序压缩打包的档案:(在win ... 
- CentOS下 SVN版本控制的安装(包括yum与非yum)的步骤记录。
		一.yum安装 rpm -qa subversion //检查是否安装了低版本的SVN yum remove subversion //如果存储旧版本,卸载旧版本SVN 开始安装 yum -y ins ... 
随机推荐
- Mybatis Generator逆向工程的使用
			一.在 idea 中使用 mybatis generator 逆向工程 1.在IDEA上创建maven工程. 2.在pom.xml中配置MyBatis逆向工程插件 <!--MyBatis自动生成 ... 
- tp3中子查询 逻辑条件是or
			直接用写sql最快 $map['_string'] = 'status=1 AND score>10'; //子查询条件字段不同 $condition['platform'] = 'swap'; ... 
- java开发环境搭建(jdk安装)和经常出现问题的探讨
			面对许多java初学者环境搭建出现的问题 第一步: 1,首先在可以百度jdk进入oracle的官网也可以进入这个网站 https://www.oracle.com/technetwork/java/j ... 
- java170道面试题汇总+详细解析
			2013年年底的时候,我看到了网上流传的一个叫做<Java面试题大全>的东西,认真的阅读了以后发现里面的很多题目是重复且没有价值的题目,还有不少的参考答案也是错误的,于是我花了半个月时间对 ... 
- JDK9新特性-改进进程管理 API
			Java 9 这个版本对进程管理方面的改进也是相当大的.在为数不多的几次 Java 项目中,有偶尔用到多线程,但对多进程和进程方面的了解还真是太少. 我想,大部分人应该跟我一样,在编程之外知道有进程的 ... 
- mybatis generator 使用教程(生成带注释的实体类)
			引言: 最近的一个项目,由于数据库表巨多,导致需要创建N多个java实体.dao.mapper.xml映射文件,如果均使用纯手工编写,无疑需要耗费大量时间和精力.于是上网学习了mybatis gene ... 
- sm1、sm2、sm3、sm4简单介绍
			转自:https://blog.csdn.net/andylau00j/article/details/54427395 国密即国家密码局认定的国产密码算法.主要有SM1,SM2,SM3,SM4.密钥 ... 
- django自带数据库sqlite
			python manage.py makemigrations # 记录关于models.py的所有改动,但是还没有作用的数据库文件中 python manage.py migrate # 把mode ... 
- notepad++下载及安装
			下载notepad++: 官网 安装:https://jingyan.baidu.com/article/154b463109921828cb8f4151.html 如果下载的64位没有插件管理器,单 ... 
- open()操作文件
			open()函数用来读取.写文件 参数解释: r:只读 w:只写,此时进行读,会报错 a:只追加 r+:可读可写 w+:可读可写 a+:可读可写 rb\rb+\wb\wb+\ab\ab+ 针对二进制文 ... 
