我相信初学开发在SVN作为版本管理时,都估计没可能考虑到如何灵活的运用SVN来管理开发代码的版本,下面我就摘录一篇文章来简单说明SVN里的trunk,branched,tags这个三个文件目录的用法。

我将会详细说明我是如何应用SVNtrunk(树干)、branches(分支)和tags(标记)。这种方法同样被称为“branchalways”,两者非常接近。可能我所介绍的并不是最好的方法,但是它会给新手一些解释说明,告诉他们trunk、branches和tags是什么,并且该如何去应用它们。

——简单的对比

SVN的工作机制在某种程度上就像一颗正在生长的树:

一颗有树干和许多分支的树

分支从树干生长出来,并且细的分支从相对较粗的树干中长出

一棵树可以只有树干没有分支(但是这种情况不会持续很久,随着树的成长,肯定会有分支啦,^^)

一颗没有树干但是有很多分支的树看起来更像是地板上的一捆树枝

如果树干患病了,最终分支也会受到影响,然后整棵树就会死亡

如果分支患病了,你可以剪掉它,然后其他分支还会生长出来的哦!

如果分支生长太快了,对于树干它可能会非常沉重,最后整棵树会垮塌掉

当你感觉你的树、树干或者是分支看起来很漂亮的时候,你可以给它照张相,这样就就可以记得它在那时是多么的赞。

——Trunk

SVN组成Trunka,Trunk是放置稳定代码的主要环境,就好像一个汽车工厂,负责将成品的汽车零件组装在一起。

以下内容将告诉你如何使用SVNtrunk:

除非你必须处理一些容易且能迅速解决的BUG,或者你必须添加一些无关逻辑的文件(比如媒体文件:图像,视频,CSS等等),否则永远不要在trunk直接做开发

不要因为特殊的需求而去对先前的版本做太大的改变,如何相关的情况都意味着需要建立一个branch(如下所述)

不要提交一些可能破坏trunk的内容,例如从branch合并

如果你在某些时候偶然间破坏了trunk,bringsomecakethenextday(”withgreatresponsibilitiescome…hugecakes”)

——Branches

SVN组成branches,一个branch就是从一个SVN仓库中的子树所作的一份普通拷贝。通常情况它的工作类似与UNIX系统上的符号链接,但是你一旦在一个SVNbranch里修改了一些文件,并且这些被修改的文件从拷贝过来的源文件独立发展,就不能这么认为了。当一个branch完成了,并且认为它足够稳定的时候,它必须合并回它原来的拷贝的地方,也就是说:如果原来是从trunk中拷贝的,就应该回到trunk去,或者合并回它原来拷贝的父级branch。

以下内容将告诉你如何使用SVNbranches:

如果你需要修改你的应用程序,或者为它开发一个新的特性,请从trunk中创建一个新的branch,然后基于这个新的分支进行开发

除非是因为必须从一个branch中创建一个新的子branch,否则新的branch必须从trunk创建

当你创建了一个新branch,你应当立即切换过去。如果你没有这么做,那你为什么要在最初的地方创建这个分支呢?

——Tags

SVN组成Tags。从表面上看,SVNbranches和SVNtags没有什么差别,但是从概念上来说,它们有许多差别。其实一个SVNtags就是上文所述的“为这棵树照张相”:一个trunk或者一个branch修订版的命名快照。

以下内容将告诉你如何使用SVNtags:

作为一个开发者,永远不要切换至、取出,或者向一个SVNtag提交任何内容:一个tag好比某种“照片”,并不是实实在在的东西,tags只可读,不可写。

在特殊或者需要特别注意的环境中,如:生产环境(production)、?(staging)、测试环境(testing)等等,只能从一个修复过的(fixed)tag中checkout和update,永远不要commit至一个tag。

对于上述提及到的环境,可以创建如下的tags:“production”,“staging”,“testing”等等。你也可以根据软件版本、项目的成熟程度来命名tag:“1.0.3”,“stable”,“latest”等等。

当trunk已经稳定,并且可以对外发布,也要相应地重新创建tags,然后再更新相关的环境(production,staging,etc)

——工作流样例

假设你必须添加了一个特性至一个项目,且这个项目是受版本控制的,你差不多需要完成如下几个步骤:

使用SVNcheckout或者SVNswitch从这个项目的trunk获得一个新的工作拷贝(branch)

使用SVN切换至新的branch

完成新特性的开发(当然,要做足够的测试,包括在开始编码前)

一旦这个特性完成并且稳定(已提交),并经过你的同事们确认,切换至trunk

合并你的分支至你的工作拷贝(trunk),并且解决一系列的冲突

重新检查合并后的代码

如果可能的话,麻烦你的同事对你所编写、更改的代码进行一次复查(review)

提交合并后的工作拷贝至trunk

如果某些部署需要特殊的环境(生成环境等等),请更新相关的tag至你刚刚提交到trunk的修订版本,使用SVNupdate部署至相关环境

  1. 简介

    1. 我们都知道SVN是管理项目源代码的软件,可以把我们开发中的各个阶段的代码记录下来,供我们以后来使用,那么SVN具体的结构你是否知道呢?下面我们来介绍一下它的基本结构
  1. Trunk、Branches、Tags、作用

    1. Trunk

      1. 这是SVN目录的主分支,表示日常开发中的项目,任何时候Trunk里包含的都是最新的开发代码。 这里的代码将会工作到你的下一个主要发布版本。
      2. Trunk应该只被用来开发将会成为你的下一个重要版本的代码。
      3. 几乎常常人们只使用trunk来存放他们的代码。发放了一个版本后继续在其上进行下一版开发。这样开发是混论的,如果出现大的Bug往往不好恢复到之前版本,因此,增加了一个Branches文件
    1. Branches

      1. 常用的Branches分支有好几种类型,这里列出常用的几种。
      2. Release Branches
        1. 当trunk达到准备发布的阶段时(或者你想冻结新特色的添加时),你应该创建一个release branches。
      1. Bug fix branches

        1. 分支也可以用于处理trunk或release branches里发现的严重的Bug。
      1. Experimental branches

        1. 有时你想将某个新技术引进项目。这很好,但是你当然不想赌上你的整个项目。想象一下,你想把你的Web程序从PHP4改为PHP5。你要花多少时间?在这期间你的trunk停止使用?直到你把所有到PHP5的转换做完
    1. Tags

      1. 一般情况下,tag,是用来做一个milestone的,不管是不是release,都是一个可用的版本。这里,应该是只读的。
      2. 在SVN中Tag和Branches,在一个选项里面创建时区别不明显,Tags中存放的也是Trunk的一个副本,只不过是只读的,不可以修改,权限不同。
  1. 意义

    1. SVN解决了我们数据备份、 版本控制、 数据同步等面对的问题,因而深受很多人喜爱和使用,它是一个不错的管理知识的软件工具。
    1. 我们自己也可以用SVN管理我们的知识。

SVN中trunk、branches、tag的使用相关推荐

  1. SVN中trunk,branches,tags用法详解

    Subversion有一个很标准的目录结构,是这样的. 比如项目是proj,svn地址为svn://proj/,那么标准的svn布局是 svn://proj/|+-trunk+-branches+-t ...

  2. 理解SVN中trunk,branches,tags

    2019独角兽企业重金招聘Python工程师标准>>> Subversion有一个很标准的目录结构: project +-- trunk +-- branches +-- tags  ...

  3. SVN的trunk branch tag

    Subversion有一个很标准的目录结构,是这样的. 比如项目是proj,svn地址为svn://proj/,那么标准的svn布局是 svn://proj/|+-trunk+-branches+-t ...

  4. SVN 中trunk、branches、tags都什么意思

    为什么80%的码农都做不了架构师?>>>    1.trunk是主分支,是日常开发进行的地方.2.branches是分支.一些阶段性的release版本,这些版本是可以继续进行开发和 ...

  5. SVN 中trunk、branches、tags都什么意思?

    1.trunk是主分支,是日常开发进行的地方. 2.branches是分支.一些阶段性的release版本,这些版本是可以继续进行开发和维护的,则放在branches目录中.又比如为不同用户客制化的版 ...

  6. SVN中trunk、branch、tag区别

    虽然一直都在用svn作项目管理,但是一直都是傻傻的分不清主干.分支.今天小编就来详细介绍一下: [branch] 分支:版本控制系统的一个特性就是能够把各种修改分离出来放在开发品的一个分割线上.这条线 ...

  7. svn如何取消某个文件的版本管理_怎样去除SVN中的某个版本之前的所有版本

    地狱门神 在某些时候,我们可能需要一个存放二进制文件的SVN库,用来保存每日构建的结果等. 但是这种库会趋于越来越大,最后会占用很多磁盘空间. 这时我们会想到能不能删掉某个版本之前的所有版本,以节省磁 ...

  8. SVN中tag branch trunk用法详解

    来源:http://developer.51cto.com/art/201005/201718.htm 本节主要讲解一下SVN中tag branch trunk的用法,在SVN中Branch/tag在 ...

  9. SVN中的trunk branches tags

    SVN中的trunk branches tags trunk:   表示开发时版本存放的目录,即在开发阶段的代码都提交到该目录上. branches:   表示发布的版本存放的目录,即项目上线时发布的 ...

最新文章

  1. Coding and Paper Letter(二十)
  2. 【深度学习】实战深度学习检测疟疾
  3. mysql事务隔离级别与锁_mysql事务隔离级别与锁
  4. 彩虹云任务极致精简版--PHPcron程序
  5. 关于在Visual Studio 2019预览版中的用户体验和界面的变化
  6. c语言终极面试宝典 pdf,C语言终极面试--编程
  7. 需要用sq语句 修改大批量用户的密码_网站文章seo优化及修改已收录文章建议
  8. Visual Studio 2010 Beta 2 公开下载地址
  9. 移动端图片上传老失败
  10. Ubuntu下利用QSS、WPS破解wpa/wpa2加密
  11. Github 爆火!程序员疯抢的 Java 面试宝典(PDF 版)限时开源
  12. c语言上机ex11答案,全国计算机等级考试C语言南开100题(上机必考).doc
  13. 控制WINDOWS,使电脑说话的小玩意
  14. 堆晶结构_火成堆晶成因的超镁铁质岩
  15. IDA安卓动调 模拟器手机(详细)
  16. 零基础入门WordPress安装详细教程(图文)
  17. 织梦教程网模板+Wap端
  18. Peppa's menu
  19. 4.Python数据容器之字符串(str)
  20. java计算机毕业设计河东街摊位管理系统源码+mysql数据库+系统+LW文档+部署

热门文章

  1. ffmpeg解码的软解及硬解(cuda和qsv)使用方法
  2. python从图片提取文字_Python从图片提取文字
  3. 2022年硕士研究生招生考试初试模拟试题参考答案
  4. NUC972资料整理
  5. 遗传编程的伦理问题:让科技发展更符合道德规范
  6. mybatis 自动生成dao mapper 文件
  7. 图的十字链表存储法详解
  8. 普通用户使用sudo命令,获得管理员权限
  9. python opencv入门 BRIEF算法(36)
  10. [PAT B1046]划拳