赞
踩
SVN和GIT都是比较流行的软件配置管理工具,SVN和GIT最大的不同是Git是一款分布式的版本控制系统,有本地和远程两个版本库,而SVN是一款集中式的版本控制系统,只有一个远程版本库。
由于svn不是分布式,因此把svn版本库保存在一台服务器上是不安全的,如果该服务器损坏,可能永久性失去SVN版本库。为了避免这样的情况发生,我们就需要把SVN版本库进行物理备份,将其备份到另外一台服务器上。
今天介绍一种通过svnsync命令进行镜像备份的方法。
本文章介绍的操作方法适用于Windows环境下,其他环境(如Linux等)也大同小异,主要是创建hook文件有些区别。
假设源SVN和备份SVN地址如下:
源SVN:https://PC_SOURCE_IP/svn/src_svn;
备份SVN:https://PC_BACKUP_IP/svn/dest_svn。
创建一个空的备份库,例如取名为dest_svn;
分别在源SVN仓库和备份SVN仓库创建一个用户,例如取名为sync_user,要求对源SVN和备份SVN都具有读写权限(在仓库的conf文件夹下,通过修改svnserve.conf、passwd、authz等文件创建);
在备份SVN仓库的hooks目录下,新建一个空的pre-revprop-change.bat文件(也可以在此文件中编写一些条件限制,例如要求必须用户名为XXX时,才能提交版本属性修改);
初始化备份SVN,在CMD命令行模式下输入下列命令:
svnsync init https://PC_BACKUP_IP/svn/dest_svn https://PC_SOURCE_IP/svn/src_svn --username sync_user --password 用户密码
同步SVN,在CMD命令行模式下输入下列命令,进行一次全备份过程:
svnsync sync https://PC_BACKUP_IP/svn/dest_svn
在源SVN仓库的hooks目录下,新建一个post-commit.bat文件,在该文件中写入下列语句,可实现每次在源SVN中commit时自动备份到备份SVN中:
svnsync sync --non-interactive https://PC_BACKUP_IP/svn/dest_svn --username sync_user --password 用户密码
exit 0
提示“svnsync: E165006: Repository has not been enabled to accept revision propchanges;
ask the administrator to create a pre-revprop-change hook”时,需要创建一个pre-revprop-change文件,参照上述第3步骤;
提示“Failed to get lock on destination repos, currently held by ‘localhost.localdomain:XXX-XXX-XXX-XXX-XXX(随机数)’”时,可能是在使用 svnsync sync同步时异常终止造成的被锁,可使用如下命令解决此异常:
svn propdel svn:sync-lock --revprop -r HEAD https://PC_BACKUP_IP/svn/dest_svn
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。