SVN跨版本库迁移目录并保留提交日志

来源:互联网 发布:清翔单片机 原理图 编辑:程序博客网 时间:2024/05/04 13:30

SVN跨版本库迁移目录并保留提交日志

这几天有这样一个问题,现在有一份代码code在版本库reposA/dirB/下,现在想把它移动到reposB/dirAA/下,本来打算交给SA做,没想到SA似乎也不太懂的样子。于是,自己在VPS搭建了一个svnserver,然后在网上查了一下资料,确实没有明确的攻略,不过,综合一下,却也解决了问题。

需要达到的目的是:

1. 将代码移动到新的版本库

2. 将原始的提交记录保留

版本库的结构如下,有reposA和reposB这两个版本库,然后红色的reposA/dirB/code就是需要移动的代码目录。本来打算用svn move来做的,后来发现因为是不同的版本库,所以这个想法被淘汰了。于是就要在server上想办法了,svnadmin有两个参数dump和load可以将版本库提取出来/加载进去,还有命令svndumpfilter可以过滤某些不想要/只想要的目录,这些就足以达到目的了。

版本库的结构如下,要将code移动到reposB/dirAA下边:

 

于是,要开始喽
注意,svn命令是在svn client端执行的,svnadmin svnserver svndumpfilter都是在svn server端执行的。

1234567891011121314
#进入svn版本库目录cd /opt/svndata ls#reposA  reposB #将reposA导出到一个文件中svnadmin dump reposA/ > f1 #将reposA中的code过滤出来,svndumpfilter include表示只保留制定的目录和文件svndumpfilter include dirB/code < f1 > f2 #将dumpfile2导入相应的目录,也就是reposB/dirAA/,用parent-dir来指定svnadmin load reposB --parent-dir dirAA < f2

这个时候会有提示说

1
svnadmin: File not found: transaction '1-1', path 'dirAA/dirB/code'

这个时候,需要给reposB新建一个dirB文件夹

123
mkdir /path/to/reposB/dirAA/dirBsvn add /path/to/reposB/dirAA/dirBsvn ci -m "新增临时文件夹" /path/to/reposB/dirAA/dirB

再次执行命令

1
svnadmin load reposB --parent-dir dirAA < f2

就会得到

1234
...    * adding path : dirAA/dirB/code ... done.    * adding path : dirAA/dirB/code/fileA ... done....

然后,code文件夹现在在reposB/dirAA/dirB/code/这个路径,可以使用svn mv在客户端移动目录

1
svn mv /path/to/reposB/dirAA/dirB/code/ /path/to/reposB/dirAA/

这样就把reposA/dirB/code/转移到了reposB/dirAA/code/,并且保留了相应的提交日志,目标达成。

0 0