一、初级篇

版本库数据的移植:svnadmin dump、svnadmin load

导出: $svnlook youngest test //查看到目前为止最新的版本号 $svnadmin dump test > dumpfile //将指定的版本库导出成文件dumpfile

导入: $svnadmin load newtest

二、中级篇

1$svnadmin dump test –r 23 >rev-23.dumpfile           //将version23导出
2$svnadmin dump test –r 100:200 >rev-100-200.dumpfile  //将version100~200导出
3对比较大的库可以分解成几个文件导出,便于备份
4$svnadmin dump test –r 0:1000 >0-1000.dumpfile
5$svnadmin dump test –r 1001:2000 --incremental >1001-2000.dumpfile
6$svnadmin dump test –r 2001:3000 --incremental >2001:3000.dumpfile
7在导入时,可以将这几个备份文件装载到一个新的版本库中
8$svnadmin load test

三、高级篇

过滤版本库历史: 

假设有三个项目的版本库/RigTMS、/DocProtect 、/Odin 现需要将这三个项目转移到独立的三个版本库中,需要做如下操作

1、转储整个版本库

1$svnadmin dump /path/to/repos > repos-dumpfile

2、将转储文件三次过滤,每次仅保留一个定级目录,即可以得到三个转储文件

1$svndumpfilter include RigTMS  RigTMS-dumpfile
2$svndumpfilter include DocProtect  DocProtect-dumpfile
3$svndumpfilter include Odin Odin-dumpfile

3、虽然现在的RigTMS、DocProtect、Odin都可以用来创建一个可用的版本库,但他们保留了原版本库的精确路径结构(例如: RigTMS的顶级目录为/RigTMS/trunk、/RigTMS/branches、/RigTMS/tags,而非我们所需要的/trunk、/branches、/tags),如果要实现目标,需要编辑转储文件,调整Node-path和Copyfrom-path头参数,将路径/RigTMS删除,同时还要转储数据中创建RigTMS目录的部分。

1Node-path:RigTMS
2    Node-action:add
3    Node-kind:dir
4    Content-length:0

注意点:如果使用手工编辑dumpfile文件来移除一个顶级目录,需要注意不要让使用的编辑器将换行符转换为本地格式(比如将/r/n转换为/n),否则文件的内容就与原来的格式不符,这个转储文件就失效了。具体做法就是当你在使用编辑器打开文件的时候,编辑器会提示用户是否需要转换格式,一定要选择“否”,切记!!切记!

4、接下来就是创建三个新的版本库,然后将新过滤出来并修改好的三个转储文件导入

1$svnadmin create RigTMS;svnadmin load RigTMS 

备份环境注意点: 

1、确保没有其他进程访问版本库,关闭apache、svnserve服务 

2、成为版本库的管理员,如果以其他身份还原版本库,可能会改变版本库文件的访问权限,导致在恢复后依旧无法访问 

3、svnadmin recover /path/to/repos 

4、重新启动服务进程