前段时间把SVN版本库从win迁移到了Linux上,没隔几天那台win的磁盘就严重坏道了。。。。这TMD什么运气!linux
花费了点时间研究了下svn本身的同步工具。写个日志记录下。缓存
注意:svnsync要求svn版本1.4+服务器
下面的内容来自svnbook-1.4
svnsync svnsync是Subversion的远程版本库镜像工具,它容许你把一个版本库的内容录入到另外一个。 在任何镜像场景中,有两个版本库:源版本库,镜像(或“sink”)版本库,源版本库就是svnsync获取修订版本的库,镜像版本库是源版本库修订版本的目标,两个版本库能够是在本地或远程—它们只是经过URL跟踪。 svnsync进程只须要对源版本库有读权限;它不会尝试修改它。可是很明显,svnsync能够读写访问镜像版本库。 警告 svnsync对于不能做为镜像操做一部分的修改很是敏感,为了防止发生这个状况,最好保证svnsync是惟一能够修改镜像版本库的进程。 svnsync选项 --config-dir DIR 指导Subversion从指定目录而不是默认位置(用户主目录的.subversion)读取配置信息。 --no-auth-cache 阻止在Subversion管理区缓存认证信息(如用户名密码)。 --non-interactive 若是认证失败,或者是不充分的凭证时,防止出现要求凭证的提示(例如用户名和密码)。这在运行自动脚本时很是有用,只是让Subversion失败而不是提示更多的信息。 --password PASS 指出在命令行中提供你的密码—另外,若是它是须要的,Subversion会提示你输入。 --username NAME 表示你要在命令行提供认证的用户名—不然若是须要,Subversion会提示你这一点。
来源SVN:192.168.2.5网络
备份SVN:192.168.3.10dom
$ svnadmin create svn-mirror
配置来源、备份SVN,建立用户:syncusersvn
请确认syncuser用户对备份SVN有写入权限。对来源SVN有读取权限。且密码相同。工具
#!/bin/sh USER="$3" # 限制只有syncuser用户才能提交版本属性修改到此版本库 if [ "$USER" = "syncuser" ]; then exit 0; fi echo "Only the syncuser user may change revision properties" >&2 exit 1 # 固然某些网络教程说的是你能够直接清空而后写入exit 0 ,这种方法虽然能够作,可是注意svnbook中的这句话: # svnsync的通信议对于源和目标版本库版本历史的不一致很是敏感,所以,虽然svnsync没法要求目标版本库是只读的,[34]最好的办法就是只容许镜像进程修改目标版本库内容。(PS:镜像==来源SVN 目录==备份SVN) # [34] 实际上,它不是真的彻底只读,或者svnsync自己有时间将版本库历史拷入。
配置备份SVN的start-commit hook【可选,但建议配上】post
#!/bin/sh USER="$2" # 限制只用syncuser用户才能提交版本修改到版本库 if [ "$USER" = "syncuser" ]; then exit 0; fi echo "Only the syncuser user may commit new revisions" >&2 exit 1
初始化备份SVN测试
$ svnsync initialize http://192.168.3.10/svn-mirror \ http://192.168.2.5/Dev-rep \ --username syncuser --password syncpass Copied properties for revision 0. # initialize 能够简写为 init 因此上面的命令能够写做以下: $ svnsync init http://192.168.3.10/svn-mirror \ http://192.168.2.5/Dev-rep \ --username syncuser --password syncpass # 注意 # 提供给svnsync的URL必须是指向目标和源版本库的根目录,这个工具不支持对版本库子树的镜像处理。
在备份SVN测试数据同步spa
$ svnsync synchronize http://192.168.3.10/svn-mirror \ --username syncuser --password syncpass
# 注意
# svnsync的最第一版本(在Subversion 1.4)有一些缺陷—-用来认证的--username和--password命令行参数同时做用于源和目标版本库。
# 显然,咱们没法保证同步的用户认证信息是相同的,若是不同,用户使用非交互模式(--non-interactive选项)来运行svnsync时会遇到这个问题(PS:也就是认证没法经过)。 # 如今有趣的部分开始了,经过一个单独的子命令,咱们能够告诉svnsync将全部镜像的修订版本从源版本库拷贝到目标版本库。
# [35]svnsync synchronize子命令会查看目标版本库特定修订版本的属性,而且检测同步的版本库是哪个,以及最新镜像的修订版本是0。而后它会查询源版本库,检测其最新的修订版本。
# 最后,它会询问源版本库服务器来开始重演从修订版本0到最新修订版本。svnsync从源版本库服务器获得返回的结果,而后将其做为新的提交转发到目标版本库服务器。 # [35] 要预先警告一下,尽管对于普通读者只须要几秒钟就能够理解下面的输出,而对于整个镜像过程花费的时间可能会很是长。
在来源SVN配置post-commit hook,启用实时备份
$ svnsync synchronize --non-interactive http://192.168.3.10/svn-mirror \ --username syncuser --password syncpass # --non-interactive 非交互模式,若是程序须要参数,让程序自行处理
请配置pre-revprop-change hook
使用 svnsync synchronize 同步时异常终止。如:机器停电,断网等。
$ svn propdel svn:sync-lock --revprop -r HEAD http://192.168.3.10/svn-mirror
这个错误通常不会遇到,svnsync只适用于1.4+版本。请升级该SVN。