本节和大家一起学习一下SVN库结构,SVN库结构常见的主要有两种,本节做一个简单的介绍,希望通过本文SVN库结构的学习能够拓宽你的视野。
很多人对”推荐的版本库结构?”不是很清楚。””trunk有什么意义?”。
一个SVN版本库实现了一种版本化的文件系统,版本库只是一个包含目录和文件的文件系统,而且它的文件系统是版本化的,并且实现了”廉价”拷贝,让它的这种操作比传统文件系统便宜很多,但是版本库本身还是像一个文件系统:SVN本身没有特别的目录或名称用来代表trunk或branches,他们只是文件系统的普通目录,这依赖于你给这些目录名和结构的一种意义。
也就是说,社区已经采纳了多种普通的库结构作为***实践,因此一个人可以将其视为推荐方式。如果你的版本库是公共访问的,根据这些习惯,用户可以方便的访问版本库来查找他们所需要的。
有两种常见的SVN库结构:
***种SVN库结构:
trunk
branches
tags
版本库包含一个项目或一组紧密联系项目的***选择,这个库结构非常好用,因为分支与标签整个项目或一组项目会非常简单,只需要一个简单的命令:
svncopyurl://repos/trunkurl://repos/tags/tagname-m"Createtagname"
这可能是最常用的版本库结构,被许多开源项目采用,就像Subversion本身和Subclipse,这是大多数主机站点,如Tigris.org,SourceForge.net和GoogleCode遵循的方法,这些站点的每个项目有自己的版本库。
另一种SVN库结构是针对一个版本库包含不相关项目的***选择。
ProjectA
trunk
branches
tags
ProjectB
trunk
branches
tags
在这种库结构里,每个项目会存在***目录里,然后该目录之下创建trunk/branches/tags,其中与***种库结构相同,这只是将项目放到自己版本库方式的替换,他们都在一个版本库中。Apache软件基金会使用这种库结构方式来存放他们的所有项目在一个版本库。
通过这种库结构,每个项目都有自己的分支和标签,可以很容易使用一个命令创建分支和标签,就像前面展示的:
svncopyurl://repos/ProjectA/trunkurl://repos/ProjectA/tags/tagname-m"Createtagname"
这种库结构可以简单的创建同时包含ProjectA和ProjectB的标签,你可以这样做,但是需要多个命令,你也要决定是否创建一个特别的目录存放这种分支和标签,如果你需要经常这样做,你或许应该考虑***种SVN库结构。至于版本库中目录的名称,再说一遍:只是一种习惯,他们在Subversion中没有特别含义。
“trunk”可以认为是项目的开发主线,你可以称之为“main”,”mainline”,”production”或任何你喜欢的名字。
“branches”是放置分支的地方,人们因各种目的使用分支,你或许希望通过特性分支或客户修改分支来隔离你的发布或维护分支等,在这个例子里,你可以在branches创建一层目录,或只是在***目录创建多个分支目录。
“tags”也不会被SVN特别对待,他们只是习惯,或许通过钩子脚本或授权规则进行强制,来指明你创建了一个时间点的快照,通常情况下tags与分支的区别就是tags一旦创建不能修改,你也可以将标签目录叫做”releases”,”snapshots”,”baselines”或任何你喜欢的。记住,名称对你有意义,不是SVN。***,SVN的架构,全局修订版本经常使得标签没有必要,我不知道只是因为要创建tag而创建tag有什么意义,如果你需要在特定时间点重建软件,你可以通过svnlog来确定相关的修订版本号。tags对于版本库的”外部”用户很有用,或许QA/Release团队需要执行构建,或许是一个内部开发小组希望在另一个产品使用发布版本,或是外部用户或客户希望根据字面含义从版本库获取发布快照,在这些场景中,创建tag是保证获取正确代码的最简单方法,也需要有好的交流机制来指明发布快照。
***,我希望指出SVN版本库的库结构是可以修改的,你可以一直重组和重构库结构,最坏情况下,会让用户调整他们的工作拷贝,但不会让你从头再来,你应该自由的改名,移动目录或任何你希望改变版本库的方式去做。本文关于SVN库结构的内容讲解完毕。
【编辑推荐】