SVN版本库实时备份整理
Posted 要千
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SVN版本库实时备份整理相关的知识,希望对你有一定的参考价值。
因为公司最近SVN服务器的文件特别多,数据量很大,有500g,而用于备份的外接磁盘除了故障,因此需要在这段时间对svn服务器上的数据做备份,所以特地研究了下svn库的备份,因为平时不怎么接触服务端,一般就用svn客户端TortoisSVN对代码checkOut,commit,update简单的操作。所以整理了份不同服务器间进行库备份的文档,并记录下来,供大家参考,也方便日后复用。
svn备份一般采用三种方式:
1)svnadmin dump
2)svnadmin hotcopy
3)svnsync
优缺点分析
==============
第一种svnadmin dump是官方推荐的备份方式,优点是比较灵活,可以全量备份也可以增量备份,并提供了版本恢复机制。
缺点是:如果版本比较大,如版本数增长到数万、数十万,那么dump的过程将非常慢;备份耗时,恢复更耗时;不利于快速进行灾难恢复。
个人建议在版本数比较小的情况下使用这种备份方式。
第二种svnadmin hotcopy原设计目的估计不是用来备份的,只能进行全量拷贝,不能进行增量备份;
优点是:备份过程较快,灾难恢复也很快;如果备份机上已经搭建了svn服务,甚至不需要恢复,只需要进行简单配置即可切换到备份库上工作。
缺点是:比较耗费硬盘,需要有较大的硬盘支持(俺的备份机有1TB空间,呵呵)。
第三种svnsync实际上是制作2个镜像库,当一个坏了的时候,可以迅速切换到另一个。不过,必须svn1.4版本以上才支持这个功能。
优点是:当制作成2个镜像库的时候起到双机实时备份的作用;
缺点是:当作为2个镜像库使用时,没办法做到“想完全抛弃今天的修改恢复到昨晚的样子”;而当作为普通备份机制每日备份时,操作又较前2种方法麻烦。
注:上述介绍摘自网络
下面进入正题,笔者今天介绍的是第三种方式。
--------------------------------------------------------------------------------------------------
本文中设备:
Window笔记本(Lenovo y400) ip:10.16.122.49 库d:/Repositories/MyRepository01
VMware虚拟机(Centos6.7) ip:192.168.193.100 库/repo/svn/svn-mirror
本文做备份采用的SVN Server提供的svnsync命令,这种方式备份其实就是做镜像,备份服务器上安装SVN Server(SubVersion)即可提供svn服务
虽然文中将的是是window同步至linux,其实反之或者同类型服务器之间都类似,不同的是脚本类型不同window脚本*.bat ,Linux脚本随意命名,需要赋予执行权限
windows需准备工作:
1更改window服务器上的同步库配置文件
进入安装
SVN Server
时配置的的仓库目录
D:\\Repositories\\MyRepository01\\hooks
复制
post-commit.tmpl
文件
,
重命名
post-commit.bat
并编辑,
删除尾部没有以
#
开始的所有行,并在尾部加入:
svnsync sync --non-interactive http://192.168.193.100/svn-mirror --username admin1 --password 123456
注:参数
--non-interactive
为非交互模式
username
和
password
为能通过
svn
认证的用户名和密码
192.168.193.100
为
Linux
服务器的
ip
2打开注册表(win+r àregedit)
应该都是64位的机器吧现在,注意键名带引号
1. for 32-bit system(32位):
[HKEY_LOCAL_MACHINE\\SOFTWARE\\VisualSVN\\VisualSVN Server]
添加 "CreateGnuTLSCompatibleCertificate"=dword:00000001
2. for 64-bit system(64位):
[HKEY_LOCAL_MACHINE\\SOFTWARE\\Wow6432Node\\VisualSVN\\VisualSVN Server] 添加"CreateGnuTLSCompatibleCertificate"=dword:00000001
window上打开VisualSVN Server Manager
选择Action(操作)—Properties如下图:
1,Network选项卡中将Use secure connection(https://)前的复选框去掉勾选,
2,看图
直至创建self-signed certificate结束。
注
:
如果没有上述的准备的话在
linux
上执行下面的
svnsync init file:usr/backuprepohttp://yao-pc/svn/MyRepository01/
时候,会报:
SSLhandshake failed: SSL
错误:
Keyusage violation in certificate has been detected
的错,因为
virtual svn
在生成鉴权数据的时候使用了一个插件,而这个插件是
OpenSSL
支持的,但
GnuTls
是不支持
Linux
服务器端操作
1,
创建
Linux
用户和用户组
(
重要
)
此用户是使用
http
协议访问
svn
库的认证用户
# groupadd admin
# useradd admin1 -g admin
# passwd admin1
2,linux服务器中安装SubVersion
命令:
# yum install subversion
# yum install mod_dav_svn
#
为了
http
协议
http://ip/repo
访问
svn
库
,
默认只能
svn://ip/repo
形式
3,创建版本库svn-mirror(随意取名)
# mkdir –p /repo/svn
#
创建存放
svn
库的根目录
#
svnadmin create /repo/svn/svn-mirror
4将/repo授权给用户admin1及其组
# chown –R admin1:admin /repo
5, 配置备份SVN(Linux)的pre-revprop-changehook(钩子)
# cd /repo/svn/svn-mirror/hooks
# cp pre-revprop-change.tmpl pre-revprop-change
# chmod +x pre-revprop-change
# vim pre-revprop-change
清空并添加如下脚本
#!/bin/sh
USER="$3"
if [ "$USER" = "admin1" ]; then exit 0; fi
echo "Only the admin1 user may change revision properties" >&2
exit 1
6,配置备份SVN的start-commit hook(可选,但建议配上)
# cp start-commit.tmpl start-commit
# chmod +x start-commit
# vim start-commit
清空并添加如下脚本
#!/bin/sh
USER="$2"
if [ "$USER" = "admin1" ]; then exit 0; fi
echo "Only the admin1 user may change revision properties" >&2
exit 1
注:建议7,8,9步骤(采用本地文件路径file:///)可以先忽略,待至第二部分配置svn的http访问(采用http模式)结束后再初始化和同步以及启动
7,初始化备份SVN
# svnsync init file:///
repo/svn/svn-mirror http://10.16.122.49/svn/MyRepository01/
8,同步版本库
# svnsync sync file:///
repo/svn/svn-mirror
9,启动svnserver
# svnserve -d -r /
repo/svn #/usr
为
svn
根目录
即创建版本仓库
svn-mirror
的目录
参数
--listen-port 3691
可以指定端口
默认
3690
配置svn的http访问
1编辑httpd.conf
# vim /etc/httpd/conf/httpd.conf
ServerName localhost:80 #去掉前面的#号
User:admin1 #将用户名更改为admin1为了下文root启动httpd时候用admin1运行
Group:admin #将组名更改为admin
2编辑subversion.conf配置文件
# vim /etc/httpd/conf.d/subversion.conf
增加:
<Location /svn-mirror>
DAV svn
SVNPath /repo/svn/svn-mirror#前文创建的版本库
</Location>
3 添加用户认证
在上一步中浏览器访问时候任何人都可以匿名访问,并且拥有写入,读取,删除权限,这不安全,下面配置用户写入时需认证
# mkdir -p /etc/svn
# htpasswd –c /etc/svn/svnusers.conf
admin1
New password:
Re-type new password:
Adding password for user admin1
4 修改上文步骤2中配置的subversion.conf文件:
<Location /svn-mirror>
DAV svn
SVNPath /repo/svn/svn-mirror
#
对库的写权限需要用户认证,访问读取时不受限制的
<LimitExcept GET PROPFIND OPTIONS REPORT>
#
使用用户名和密码认证
AuthType Basic
#
认证对话框中提示信息
AuthName "Authorization Realm"
#
认证用户的文件路径
AuthUserFile /etc/svn/svnusers.conf
#
只有认证正确才能访问
svn
库
Require valid-user
</LimitExcept>
</Location>
5 开启httpd服务
# apachectl start
#root
用户启动
浏览器访问
http://192.168.193.100/
svn-mirror
注:
svn-mirror
为
subversion.conf
中配置的
<Location /
svn-mirror
>,名称可以随意配置
6更改配置/home/admin1/.subversion/servers
# vim /home/admin1/.subversion/servers
#
将前面的
#
号放开,并改为
yes
,为了取消在同步时候需要互动(手动填写提示信息)
store-plaintext-passwords = yes
7
初始化
svn
库
(Linux
上执行
)
# svnsync init http://192.168.193.100/svn-mirror http://10.16.122.49/svn/MyRepository01/--username admin1 –-password 123456
8
同步
svn
库
# svnsync sync http://192.168.193.100/svn-mirror --usernameadmin1 --password 123456
测试
新建任意文件提交至MyRepository01
库中,检查
svn-mirror
库中的文件是否已经更新
以上是关于SVN版本库实时备份整理的主要内容,如果未能解决你的问题,请参考以下文章