如用svnsync同步备份两台机器的svn 。(就以linux服务器到windows服务器为例子)
要同步的项目名称:source_svn
svn版本库1 。4 以上源目录:svn://192.168.16.199/source_svn同步目标目录: http://目标IP:8080/source_svnbak
方法:
1.如果目标目录存在相同的项目,请先清除,重新建立空项目2.在目标服务器中建立svn版本库source_svnbak svnadmin create source_svnbak (svnadmin是svn的命令如果没有将svn目录放到环境变量需要在其目录里面使用该句若是windows可以直接点击右键创建svn)
3.需要在hooks中将pre_revprop_change.tmpl改为pre_revprop_change.bat并将内容清空然后输入exit 0
4.执行初始化
svnsync init svn://目标:ip:端口号/source_svnbak svn://192.168.16.199/source_svn
(执行到这一般会出现一个问题 svnsync: 认证失败)解决:需要把源文件source_svn中的conf拷贝到目标source_svnbak中替换conf文件
如果成功他会提示你输入用户名和密码(注:第一个是Administrator这个我觉得不用管随便输入,确定后才是你svn中填写的用户名和密码在conf中的文件有配置)
正确后,显示
Copied properties for revision 0.(复制版本 0 的属性。)5
执行同步
svnsync sync svn://目标ip和端口号/source_svnbak --username xxxx --password xxxx(一般端口号不用写除非端口号不是默认安装过的需要写,用户名和密码都在conf中有配置)
即svnsync sync 目标库
正确执行后,显示
复制版本号和提交数据等信息
6.更新同步
在source_svn的hooks下面,添加post-commit 脚本
可拷贝post-commit.tmpl
即
cp post-commit.tmpl post-commit
然后
把 post-commit 中,最后两行替换为
svnsync sync --non-interactive svn://目标ip:(端口号)/source_svnbak --username xxx --password xxx
即提交更新后,即执行同步命令,不进行交互
把post-commit 设为755权限。
ps:
如果post-commit脚本出错,或者无可执行权限,在提交更新时会报错
错误处理 :在源端 ,同步用的帐号需要有读权限 ,在目的端同步帐号需要读写权限 .权限分配合理后 , 基本上就不会出现其他错误 .如果出现以下列出的之外的错误 ,请先检查一下 svn服务是否可正常使用 .比较常见的错误是 :
# svnsync initialize DEST_URI SRC_URI --username cax --password password_for_cax
svnsync: DAV request failed; it's possible that the repository's pre-revprop-change hook either failed or is non-existent
svnsync: At least one property change failed; repository is unchanged这是由于系统中没有 pre-revprop-change钩子脚本导致的 ,该文件在版本库的 ~/hooks/��� ,只需拷贝一份即可 .
cp -pf hooks/pre-revprop-change.tmpl hooks/pre-revprop-change如果是 windows 系统 ,还需要清空 pre-revprop-change的内容 ,并添加后缀为 pre-revprop-change.bat在批处理文件中 , Linux 下 shell中注释符 # 不能被 batch正确解释也会重复出现该错误 .