`

svn 标准目录使用

阅读更多

 

Subversion有一个很标准的目录结构,是这样的。
比如项目是proj,svn地址为svn://proj/,那么标准的svn布局是

svn://proj/|+-trunk+-branches+-tags
这是一个标准的布局,trunk为主开发目录,branches为分支开发目录,tags为tag存档目录(不允许修改)。但是具体这几个目录应该如何使用,svn并没有明确的规范,更多的还是用户自己的习惯。

对于这几个开发目录,一般的使用方法有两种。我更多的是从软件产品的角度出发(比如freebsd),因为互联网的开发模式是完全不一样的。 1.第一种方法,使用trunk作为主要的开发目录
一 般的,我们的所有的开发都是基于trunk进行开发,当一个版本/release开发告一段落(开发、测试、文档、制作安装程序、打包等)结束后,代码处 于冻结状态(人为规定,可以通过hook来进行管理)。此时应该基于当前冻结的代码库,打tag。当下一个版本/阶段的开发任务开始,继续在trunk进 行开发。
此时,如果发现了上一个已发行版本(Released Version)有一些bug,或者一些很急迫的功能要求,而正在开发的版本(Developing Version)无法满足时间要求,这时候就需要在上一个版本上进行修改了。应该基于发行版对应的tag,做相应的分支(branch)进行开发。
例如,刚刚发布1.0,正在开发2.0,此时要在1.0的基础上进行bug修正。
按照时间的顺序

1.0开发完毕,代码冻结 
基于已经冻结的trunk,为release1.0打tag
此时的目录结构为
svn://proj/
+trunk/ (freeze)
+branches/
+tags/
+tag_release_1.0 (copy from trunk) 
2.0开始开发,trunk此时为2.0的开发版 
发现1.0有bug,需要修改,基于1.0的tag做branch
此时的目录结构为
svn://proj/
+trunk/ ( dev 2.0 )
+branches/
+dev_1.0_bugfix (copy from tag/release_1.0)
+tags/
+release_1.0 (copy from trunk) 
在1.0 bugfix branch进行1.0 bugfix开发,在trunk进行2.0开发 
在1.0 bugfix 完成之后,基于dev_1.0_bugfix的branch做release等 
根据需要选择性的把dev_1.0_bugfix这个分支merge回trunk(什么时候进行这步操作,要根据具体情况) 
这是一种很标准的开发模式,很多的公司都是采用这种模式进行开发的。trunk永远是开发的主要目录。

2.第二种方法,在每一个release的branch中进行各自的开发,trunk只做发布使用。
这种开发模式当中,trunk是不承担具体开发任务的,一个版本/阶段的开发任务在开始的时候,根据已经release的版本做新的开发分支,并且基于这个分支进行开发。还是举上面的例子,这里面的时序关系是:

1.0开发,做dev1.0的branch
此时的目录结构
svn://proj/
+trunk/ (不担负开发任务 )
+branches/
+dev_1.0 (copy from trunk)
+tags/ 
1.0开发完成,merge dev1.0到trunk
此时的目录结构
svn://proj/
+trunk/ (merge from branch dev_1.0)
+branches/
+dev_1.0 (开发任务结束,freeze)
+tags/ 
根据trunk做1.0的tag
此时的目录结构
svn://proj/
+trunk/ (merge from branch dev_1.0)
+branches/
+dev_1.0 (开发任务结束,freeze)
+tags/
+tag_release_1.0 (copy from trunk) 
1.0开发,做dev2.0分支
此时的目录结构
svn://proj/
+trunk/ 
+branches/
+dev_1.0 (开发任务结束,freeze)
+dev_2.0 (进行2.0开发)
+tags/
+tag_release_1.0 (copy from trunk) 
1.0有bug,直接在dev1.0的分支上修复



一直以来用svn 只是当作cvs,也从来没有仔细看过文档,直到今天用到,才去翻看svn book文档,惭愧

需求一: 
有一个客户想对产品做定制,但是我们并不想修改原有的svn 中trunk 的代码。

方法: 
用svn 建立一个新的branches,从这个branche做为一个新的起点来开发

代码
  1. svn  copy svn : //server/trunk  svn ://server/branches/ep -m "init ep"   

<script>render_code();</script>

 

Tip: 
如果你的svn 中以前没有branches这个的目录,只有trunk 这个,你可以用

代码
  1. svn  mkdir branches  

<script>render_code();</script>
新建个目录

 

需求二: 
产品开发已经基本完成,并且通过很严格的测试,这时候我们就想发布给客户使用,发布我们的1.0版本

代码
  1. svn  copy svn : //server/trunk  svn ://server/tags/release-1.0 -m "1.0 released"   

<script>render_code();</script>

 

咦,这个和branches有什么区别,好像啥区别也没有? 
是的,branches和tags是一样的,都是目录,只是我们不会对这个release-1.0的tag做修改了,不再提交了,如果提交那么就是branches

需求三: 
有一天,突然在trunk 下的core中发现一个致命的bug,那么所有的branches一定也一样了,该怎么办?

代码
  1. svn  -r  148 : 149  merge svn : //server/trunk  branches/ep   
<script>render_code();</script>
其中148和149是两次修改的版本号。很好的东西【转】
分享到:
评论

相关推荐

    SVN的标准目录结构:trunk、branches、tags

    SVN 标准目录结构:trunk、branches、tags SVN(Subversion)是一种版本控制系统,广泛应用于软件开发和项目管理中。在 SVN 中,标准目录结构是指 trunk、branches、tags三个目录,这三个目录反映了软件开发的通常...

    svn目录使用规范.doc

    **SVN目录使用规范** **一、SVN目录结构** 在使用SVN(Subversion)进行版本控制时,遵循一种标准的目录结构有助于保持代码库的整洁和有序。这种结构通常包括三个主要部分:`trunk`、`branches`和`tags`。 1. **...

    SVN目录结构说明

    对于使用SVN进行版本控制的团队来说,合理的目录结构设计对于项目的长期维护和发展至关重要。 #### 二、SVN目录结构的重要性 一个清晰且逻辑性强的SVN目录结构可以带来以下好处: 1. **易于理解**:良好的目录...

    SVN管理员使用指南

    Subversion,简称SVN,是一种广泛使用的开源版本控制系统,其设计旨在管理文件和目录的版本控制,支持数据的回溯与历史修改记录查看。SVN的核心优势在于,它不仅能够处理单一文件的版本控制,还能高效地管理整个项目...

    常用项目SVN目录结构

    以上是一个标准SVN目录结构的概述,实际项目中可能根据团队习惯和项目需求进行调整。理解并遵循这样的目录结构,有助于保持项目的整洁和有序,从而提升团队的整体协作效率。在日常开发中,还应注意定期进行代码审查...

    svn使用手册

    - 点击 OK 创建版本库,此时版本库会自动包含 trunk、branches 和 tags 三个标准目录。 3. **导入项目到版本库**: - 找到项目文件夹,在文件夹上点击右键,选择 SVN -&gt; 导入。 - 填写版本库 URL,可通过 ...

    SVN用户使用详细指南

    ### SVN用户使用详细指南 #### 1. 引言 ##### 1.1 目的 本指南旨在为用户提供Subversion(以下简称SVN)的基本使用方法及深入操作技巧,帮助用户快速掌握SVN的核心功能与应用场景,从而提高开发效率与项目协作能力...

    SVN版本控制安装及使用说明

    **SVN 版本控制安装及使用说明** **一、SVN 介绍** SVN(Subversion)是一种开源的版本控制系统,用于管理文件和目录的变更历史,支持多人协同工作,使得团队成员可以在同一份代码上进行修改并合并更改,同时保持...

    svn乱码解决

    此外,为了避免类似问题再次发生,建议团队统一文件编码标准,如使用UTF-8,并确保所有成员的编辑器都配置为支持这种编码。同时,对于包含特殊字符的文件名,最好在创建时就避免使用,或者在导入svn前进行适当的转码...

    svn-doc文件夹结构.rar

    1. **标准目录结构**:在Java项目中,通常会遵循Maven或Gradle的标准目录结构。Maven的默认结构包括`src/main/java`(存放Java源代码),`src/main/resources`(放置非编译资源如配置文件),`src/test/java`(测试...

    Eclipse下SVN使用操作手册

    为了确保代码的一致性与版本管理,使用版本控制系统如SVN(Subversion)成为了一种标准实践。本文将详细介绍如何在Eclipse环境中搭建SVN服务端,以及如何在客户端上进行SVN的基本操作,实现有效的版本控制。 #### ...

    SVN清除.svn的python代码

    它利用Python的标准库以及Windows API来递归地遍历指定目录,查找并删除所有的`.svn`目录。该脚本首先通过用户输入获取目标目录,然后进行必要的路径清理,确保路径格式正确。接下来,它会询问用户是否确认删除操作...

    小组开发svn使用常识

    标准的 SVN 目录结构包括 `trunk`(主干)、`branches`(分支)和 `tags`(标签)。`trunk` 存放主项目代码,`branches` 用于创建不同的开发分支,而 `tags` 则用来保存特定版本的快照。 2. **命名规范**: 项目...

    win下的svn安装工具及安装步骤

    Subversion(简称SVN)是一种流行的版本控制系统,用于管理和跟踪文件及目录的变更。在Windows操作系统下安装和配置SVN可以帮助团队成员协同工作,有效地管理代码和文件。以下是详细的安装和配置步骤: 1. **下载...

    SVN版本管理规范

    3. 内部修订编号:内部修订编号描述了源代码的 SVN 修订号,主要由开发人员和测试人员使用。 命名规范 1. 默认 Trunk 上面的都是产品。 2. 产品 Branch 命名规范:Branch_fix_V1.2.0_20170531(创建分支时写明用途...

    64位SVN安装包

    对于大多数开源软件来说,SVN是一个标准的选择,因为其强大的功能和易用性,使得它成为了开发者之间协作和管理代码的首选工具。 安装过程中,"Setup.exe"通常是一个安装向导程序,用于引导用户完成SVN的安装步骤。...

    Windows 下面 apache+SVN配置

    1. 将SVN的bin目录下的mod_dav_svn.so、mod_authz_svn.so以及它们依赖的动态库(如libdb43.dll、intl3_svn.dll、ssleay32.dll和libeay32.dll)复制到Apache的bin目录下。 2. 修改Apache的配置文件httpd.conf,取消...

    svn插件免费压缩包

    此外,命令行客户端如`svn`也是标准的交互方式,适合高级用户和自动化脚本。 4. **插件的用途**:压缩包中的SVN插件可能包括增强型的客户端界面、自动化的脚本工具、性能优化模块或者与其他开发工具(如IDEs)集成...

    svn 管理工具(web版)

    而“svnadmin.war”文件是一个Java Web应用程序档案(WAR文件),这通常是Web服务器部署Web应用的标准格式,可能包含了该Web SVN管理工具的全部源代码和运行环境。最后,“db”文件夹可能包含了SVN仓库的实际数据库...

Global site tag (gtag.js) - Google Analytics