SVN版本分支合并

摘要:
SVNChild是与SVNMain分离的版本,即整个代码结构基本相同。当然,添加和修改一些文件是正常的。SVN中有三种类型的分支合并。这里,我们只说分支合并到主干中,主干合并到分支中。第三种类型未使用,因此不清楚。如果SVNMain主干的版本达到999,并且使用版本900创建了分支目录SVNChild,并且提交了分支目录,则SVN的总版本将达到1000。最后,需要注意的是,不同的SVN版本可能略有不同。此外,在新版本的SVN中,showlog将记录在融合过程中融合了哪些版本。融合版本为灰色,具有融合图标

  SVN,开发中常用的工具,也没什么可说的。这里只是记录一下,以免太久不用了想用的时候又忘了。

  首先已经有两个目录,一个是分支目录SVNChild,一个是主干目录SVNMain。SVNChild是从SVNMain分出来的一个版本,即整个代码结构(文件夹、代码文件)基本一样的,当然新添加了部分文件、修改文件是正常的。如果不是,则合并的选项都不是一样的。SVN的分支合并有三种,这里只说分支合并到主干,主干合并到分支两种,第三种没用过,不太清楚。分支合并到主干、主干合并到分支操作基本一样,这里就以主干合并到分支说明。

  假如SVNMain主干的版本到了999,这时用版本900建立分支目录SVNChild,提交分支目录,则总的SVN版本到了1000。那我们就要注意3个版本了,一个是主干版本999,一个是分支版本900,总SVN版本1000。注意在提交分支目录时需要在log记录其版本为900,不然以后忘了,我真不知道分支是什么版本(PS:有知道的望指教)。 

  在SVNChild上右键--TortoiseSVN--Merge进行合并。

SVN版本分支合并第1张

选择合并主干到分支,下一步

SVN版本分支合并第2张

选择正确的SVN主干路径,然后就是填写需要合并的版本。比如需要合并版本900到最新版本(分支版本就是900),则填写900-HEAD,如果中间有一些版本不需要合并,如果906,908这两个版本不需要合并,则填写为900-905,907,909-HEAD。然后就是下一步了,会有一个test merge,会进行合并模拟,可以看到哪些文件被更新......确定是所需要合并的文件后,确定就OK了。合并完成后,只是把主干上的文件合并到本地,需要提交SVNChild目录。

  最后,需要说明的是SVN版本不同可能会略有不同。还有就是SVN目录下的操作能提交的应尽快提交,一方面是防止代码丢失,另一方面是防止出现一些莫名其妙的错误。有些同事的SVN会更新不上(检查过没有冲突,没有忽略),也有过同事合并不了,没有错误,但在test merge这一步没显示任何文件被更新。后来也查不出来,把SVN目录删除重新checkout未发现什么问题。

------------------------------------------------------------------------------2014-05-25-----------------------------------------------------------------------------------

  上一次项目发布新版本时,把主干上的版本跨版本融合到发布分支上了。即主干开发已给到1999了,发布分支停留在主干的1987版本上,那么这次要更新到1992版本。但是在主干上1996版本时修复了一些BUG,而1993-1995这些版本是不能发布的。所以我就把1987-1992,1996融合到发布分支上去了,其中跳过了一些版本。这没有发现问题。

  结果最近一次发布新版本时,需要发布版本2008。由于上一次融合了版本1996,那么这些就是1992-1995,1997-2008这样了,感觉不会有问题,结果提示有冲突了。想一下,估计是1992-1995,1997-2008这些版本中修改了1996版本中的文件。因为当时发布时间很急,没来得及多想,先1992-1995融合,提交分支,然后再1997-2008这样分段融合,居然只是merge而不是conflict。用beyond comapre对比一下文件,没有发现问题,就发布了。

  现在回想一下,做了一些验证。

  首先,想一下为什么会conflict。条件是文件内容不一样(假设不能merge)并且本地的文件版本比要merge版本高或者是本地文件经过修改。文件不一样是肯定的,而且由于merge后再update会产生一个主干版本号,故就冲突了。因为我们是把主干合并到发布分支,其实我们期望的是做update,即在发布分支出现conflict时,以主干为准,直接update。但事实是,svn允许在分支上修改文件,故这要求对svn不适用,并不是所有用svn的人都不会在分支个修改文件。平时我们看到的update是因为同事修改了文件,update后版本更高。虽然我们本地的文件内容冲突,但版本高为准嘛。而不跨版本融合时(即使分多次融合,分支版本号比要merge版本高),要融合的文件版本号应该取的是主干上一次融合的版本号。

  思路有点乱,也不一定正确。总结一下。当需要跨版本融合时,要保证中间的版本(如例子中的1996)的文件在之前版本不被修改。下面做验证时:

SVN版本分支合并第3张

在上面的图中,log标明为step的修改的都是同一文件,other的则是每次都修改不同文件。发现在step中跨版本融合时,总会提示冲突

SVN版本分支合并第4张

而修改不同文件的版本,则不会有问题。

另外,在新版本的SVN中,融合时show log会记录哪些版本已融合,已融合的为灰色并有融合图标

免责声明:文章转载自《SVN版本分支合并》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇layui输入框中只允许输入整数的实现方法防止 iframe 的链接重定向父级页面下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

试下Inceptor事务表和HDFS目录的关系。

创建表,并插入数据。 查看目录结构 修改数据'1',和数据'2'的age字段,第三个字段。 看到了把,出现了9个delta版本文件。因为有了5次插入和4次update。现在执行compact,尽快,在系统compact之前完成。 查看表目录文件情况 查看表目录文件情况 create table test_tx (name string ,id...

MongoDB批量更新和批量插入的方式

最近,在调试代码中发现向MongoDB插入或者更新文档记录时若是多条的话都是采用for循环操作的,这样的处理方式会造成数据操作耗时,不符合批量处理的原则;对此,个人整理了一下有关MongoDB的批量更新和批量插入的操作流程,如下所示: @Autowired privateMongoTemplate mongoTemplate; (1)批量插入示例如下: L...

SVN搭建

1 安装SVN 官网下载:http://subversion.apache.org/packages.html SVN客户端:TortoiseSVN,官网下载:http://tortoisesvn.net/downloads.html # yum install subversion  1.新建一个目录用于存储SVN所有文件 # mkdir /svn  ...

phpstorm配置subversion服务

一、点击Subversion  二、添加svn地址  三、检出 四、可能出现的问题 Cannot load supported formats: Cannot run program "svn": CreateProcess error=2, The system cannot find the file specified  解决: 1、下载s...

[转]Ubuntu Linux下的 Opera 软件源

详情请访问:http://deb.opera.com/ Opera 官方源:最新的版本: deb http://deb.opera.com/opera/ unstable non-free或者选择稳定的版本:deb http://deb.opera.com/opera/ stable non-free(修改sources.list文件中源的列表,添加Ope...

Informatica_(3)组件

  一、Informatica介绍Informatica PowerCenter 是Informatica公司开发的世界级的企业数据集成平台,也是业界领先的ETL工具。Informatica PowerCenter使用户能够方便地从异构的已有系统和数据源中抽取数据,用来建立、部署、管理企业的数据仓库,从而帮助企业做出快速、正确的决策。此产品为满足企业级要...