转载自:http://spiritfrog.iteye.com/blog/448578 + http://magnet2008.iteye.com/blog/586578
备份策略
==============
svn备份一般采用三种方式:
1)svnadmin dump 
2)svnadmin hotcopy 
3)svnsync.

注意,svn备份不宜采用普通的文件拷贝方式(除非你备份的时候将库暂停),如copy命令、rsync命令。 
笔者曾经用 rsync命令来做增量和全量备份,在季度备份检查审计中,发现备份出来的库大部分都不可用,因此最好是用svn本身提供的功能来进行备份。

优缺点分析
============== 
第一种svnadmin dump是官方推荐的备份方式,优点是比较灵活,可以全量备份也可以增量备份,并提供了版本恢复机制。 
缺点是:如果版本比较大,如版本数增长到数万、数十万,那么dump的过程将非常慢;备份耗时,恢复更耗时;不利于快速进行灾难恢复。 
个人建议在版本数比较小的情况下使用这种备份方式。 
第二种svnadmin hotcopy原设计目的估计不是用来备份的,只能进行全量拷贝,不能进行增量备份; 
优点是:备份过程较快,灾难恢复也很快;如果备份机上已经搭建了svn服务,甚至不需要恢复,只需要进行简单配置即可切换到备份库上工作。 
缺点是:比较耗费硬盘,需要有较大的硬盘支持(俺的备份机有1TB空间,呵呵)。 
第三种svnsync实际上是制作2个镜像库,当一个坏了的时候,可以迅速切换到另一个。不过,必须svn1.4版本以上才支持这个功能。 
优点是:当制作成2个镜像库的时候起到双机实时备份的作用; 
缺点是:当作为2个镜像库使用时,没办法做到“想完全抛弃今天的修改恢复到昨晚的样子”;而当作为普通备份机制每日备份时,操作又较前2种方法麻烦。

备份的命令
==============

全备份:使用svnadmin dump或svnadmin hotcopy或svnsync来做,
hotcopy:
svnadmin hotcopy path/to/repository path/to/backup –clean-logs
dump:
svnadmin dump 版本库路径及名称 –revision 导出的版本号> 导出的命名

增量备份:使用svnadmin dump的–incremental选项来实现
svnadmin dump 版本库路径及名称 –revision 上次导出的版本号:到本次要导出到的版本号 –incremental > 导出的命名

一个技巧:如果你有一个较大的Subsersion版本库而你又想用最少的空间来将它备份下来,用这个命令(请将/repo替换成你的版本库路径)吧:
svnadmin dump –deltas /repo |bzip2 |tee dump.bz2 | md5sum >dump.md5
分步解释:最重要的一步是 -deltas,将消耗更多的CPU资源,但拥有更有效的差异存储办法。
bzip2压缩方案比gzip慢,但换来的更好的压缩率。
更有趣的是,tee方法将压缩的数据流转向到文件dump.bz2,同时将其输出到标准输出,后者有转向给了MD5摘要计算工具。

还原命令
==============
还原版本:svnadmin load 要恢复的版本库路径及名称 < 导出的命名
svnadmin hotcopy path/to/repository path/to/backup –clean-logs

svnadmin dump
==============

这是subversion官方推荐的备份方式。

1)定义备份策略: 
备份频度:每周六进行一次全量备份,每周日到周五进行增量备份 
备份地点:备份存储路径到/home/backup/svn/ 
备份命名:全量备份文件名为:weekly_fully_backup.yymmdd,增量备份文件命名为:daily-incremental-backup.yymmdd 
备份时间:每晚21点开始 
备份检查:每月末进行svnadmin load恢复试验。 
2)建立全量备份脚本: 
在~/下建立一个perl脚本文件,名为weekly_backup.pl,执行全量备份,并压缩备份文件,代码如下(本代码只针对一个库的备份,如果是多个库请做相应改动): 
     
#!/usr/bin/perl -w 
my $svn_repos="/home/svn/repos/project1"; 
my $backup_dir="/home/backup/svn/"; 
my $next_backup_file = "weekly_fully_backup.".`date +%Y%m%d`;

$youngest=`svnlook youngest $svn_repos`; 
chomp $youngest;

print "Backing up to revision $youngest\n"; 
my $svnadmin_cmd="svnadmin dump --revision 0:$youngest $svn_repos >$backup_dir/$next_backup_file"; 
`$svnadmin_cmd`; 
open(LOG,">$backup_dir/last_backed_up"); #记录备份的版本号 
print LOG $youngest; 
close LOG; 
#如果想节约空间,则再执行下面的压缩脚本 
print "Compressing dump file...\n"; 
print `gzip -g $backup_dir/$next_backup_file`;

3)建立增量备份脚本: 
在全量备份的基础上,进行增量备份:在~/下建立一个perl脚本文件,名为:daily_backup.pl,代码如下:

#!/usr/bin/perl -w 
my $svn_repos="/home/svn/repos/project1"; 
my $backup_dir="/home/backup/svn/"; 
my $next_backup_file = "daily_incremental_backup.".`date +%Y%m%d`;

open(IN,"$backup_dir/last_backed_up"); 
$previous_youngest = <IN>; 
chomp $previous_youngest; 
close IN;

$youngest=`svnlook youngest $svn_repos`; 
chomp $youngest; 
if ($youngest eq $previous_youngest) 

  print "No new revisions to backup.\n"; 
  exit 0; 

my $first_rev = $previous_youngest + 1; 
print "Backing up revisions $youngest ...\n"; 
my $svnadmin_cmd = "svnadmin dump --incremental --revision $first_rev:$youngest $svn_repos > $backup_dir/$next_backup_file"; 
`$svnadmin_cmd`; 
open(LOG,">$backup_dir/last_backed_up"); #记录备份的版本号 
print LOG $youngest; 
close LOG; 
#如果想节约空间,则再执行下面的压缩脚本 
print "Compressing dump file...\n"; 
print `gzip -g $backup_dir/$next_backup_file`; 
   
4)配置/etc/crontab文件 
配置 /etc/crontab 文件,指定每周六执行weekly_backup.pl,指定周一到周五执行daily_backup.pl; 
具体步骤俺就不啰嗦了. 
   
5)备份恢复检查 
在月底恢复检查中或者在灾难来临时,请按照如下步骤进行恢复:恢复顺序从低版本逐个恢复到高版本;即,先恢复最近的一次完整备份 weekly_full_backup.071201(举例),然后恢复紧挨着这个文件的增量备份 daily_incremental_backup.071202,再恢复后一天的备份071203,依次类推。如下: 
user1>mkdir newrepos 
user1>svnadmin create newrepos 
user1>svnadmin load newrepos < weekly_full_backup.071201 
user1>svnadmin load newrepos < daily_incremental_backup.071202 
user1>svnadmin load newrepos < daily_incremental_backup.071203 
....

如果备份时采用了gzip进行压缩,恢复时可将解压缩和恢复命令合并,简单写成: 
user1>zcat weekly_full_backup.071201 | svnadmin load newrepos 
user1>zcat daily_incremental_backup.071202 | svnadmin load newrepos 
...

svnadmin hotcopy整库拷贝方式

==============

svnadmin hotcopy是将整个库都“热”拷贝一份出来,包括库的钩子脚本、配置文件等;任何时候运行这个脚本都得到一个版本库的安全拷贝,不管是否有其他进程正在使用版本库。 
因此这是俺青睐的备份方式。

1)定义备份策略 
备份频度:每天进行一次全量备份, 
备份地点:备份目录以日期命名,备份路径到 /home/backup/svn/${mmdd} 
备份保留时期:保留10天到15天,超过15天的进行删除。 
备份时间:每晚21点开始 
备份检查:备份完毕后自动运行检查脚本、自动发送报告。 
2)建立备份脚本 
在自己home目录 ~/下创建一个文件,backup.sh:

#!/bin/bash 
SRCPATH=/home/svn/repos/; #定义仓库parent路径 
DISTPATH=/home/backup/svn/`date +\%m%d`/ ; #定义存放路径; 
if [ -d "$DISTPATH" ] 
then 
else 
   mkdir $DISTPATH 
   chmod g+s $DISTPATH 
fi 
echo $DISTPATH 
svnadmin hotcopy $SRCPATH/Project1 $DISTPATH/Project1 >/home/backup/svn/cpreport.log 2>&1; 
svnadmin hotcopy $SRCPATH/Project2 $DISTPATH/Project2 
cp $SRCPATH/access  $DISTPATH; #备份access文件 
cp $SRCPATH/passwd  $DISTPATH; #备份passwd文件 
perl /home/backup/svn/backup_check.pl #运行检查脚本 
perl /home/backup/svn/deletDir.pl  #运行删除脚本,对过期备份进行删除。

3)建立检查脚本 
在上面指定的地方/home/backup/svn/下建立一个perl脚本:backup_check.pl 
备份完整性检查的思路是:对备份的库运行 svnlook youngest,如果能正确打印出最新的版本号,则表明备份文件没有缺失;如果运行报错,则说明备份不完整。我试过如果备份中断,则运行svnlook youngest会出错。 
   
4)定义删除脚本 
由于是全量备份,所以备份不宜保留太多,只需要保留最近10来天的即可,对于超过15天历史的备份基本可以删除了。 
   在/home/backup/svn/下建立一个perl脚本:deletDir.pl

5)修改/etc/crontab 文件

在该文件中指定每晚21点执行“backup.sh”脚本。

svnsync备份

==============

使用svnsync备份很简单,步骤如下: 
1)在备份机上创建一个空库:svnadmin create Project1 
2)更改该库的钩子脚本pre-revprop-change(因为svnsync要改这个库的属性,也就是要将源库的属性备份到这个库,所以要启用这个脚本):   
  cd SMP/hooks; 
  cp pre-revprop-change.tmpl pre-revprop-change; 
  chmod 755 pre-revprop-change; 
  vi pre-revprop-change; 
  将该脚本后面的三句注释掉,或者干脆将它弄成一个空文件。 
3)初始化,此时还没有备份任何数据: 
svnsync init file:///home/backup/svn/svnsync/Project1/  http://svntest.subversion.com/repos/Project1 
  语法是:svnsync init {你刚创建的库url} {源库url} 
  注意本地url是三个斜杠的:/// 
4)开始备份(同步): 
  svnsync sync file:///home/backup/svn/svnsync/Project1 
5)建立同步脚本 
  备份完毕后,建立钩子脚本进行同步。在源库/hooks/下建立/修改post-commit脚本,在其中增加一行,内容如下: 
    /usr/bin/svnsync sync  --non-interactive file:///home/backup/svn/svnsync/Project1 
  你可能已经注意到上面的备份似乎都是本地备份,不是异地备份。实际上,我是通过将远程的备份机mount(请参阅mount命令)到svn服务器上来实现的,逻辑上看起来是本地备份,物理上实际是异地备份。

完!

snv服务器备份方案相关推荐

  1. 服务器维护简单的备份方案,服务器备份方案计划.doc

    服务器备份方案计划 服务器备份方案 一.备份服务器硬件配置 备份服务器型号IBM X206,其硬件配置如下: CPU:P4 2.8G 内存:DDR ECC512M 硬盘:3*72G SCSI硬盘. 磁 ...

  2. 企业级MySQL数据库备份方案:增量备份、全量备份、逻辑备份

    一份好的备份方案无非包括以下几点: 为什么需要备份? 备份的方式有哪些? 某几种备份方式的区别在哪? 备份实战操作概述 恢复实战操作概述 其它备注信息 那么,此文将从以上几个角度,结合一些实际的实战经 ...

  3. 开发服务器 VSS开发库 自动备份方案

    开发服务器 VSS开发库 自动备份方案     vss开发库每天备份一次,脚本如下: from F:/backup/dev_vss_backup.bat set src_dir=f:/dev_vss ...

  4. 发布服务器 bugzilla, streber 数据库备份方案

    发布服务器 bugzilla, streber 数据库备份方案 Bugzilla, Streber 目前均使用 MySQL 数据库. 备份的方法是将两个库导出为 sql 脚本,然后压缩为 zip 文件 ...

  5. 文件服务器数据备份方案,BACKUPPC服务器数据备份方案.pdf

    BackupPC 服务器数据备份方案 作者:th 日期:2013-10-25 企业服务器的数据都是非常重要的,为了确保安全,我们会做数据库备份,还要考虑应 用数据及补丁备份,仅仅是本机备份是不够的,我 ...

  6. 服务器维护简单的备份方案,几种常见的数据备份方案分享

    原标题:几种常见的数据备份方案分享 常见的数据备份系统主要有Host-Base.LAN-Base和基于SAN结构的LAN-Free.Server-Free等多种结构. Host-Based备份方式: ...

  7. qnap备份文件服务器,完整的数据备份方案

    ◆ 完整的数据备份方案 在数据安全方面Turbo NAS提供了完整的数据备份方案,包括本地备份.远程备份及云端备份. 本地备份方案包括 : ·QNAP独家备份软件NetBak Replicator · ...

  8. 常见服务器的备份方案

    常见服务器的备份方案 备份 备份策略 备份频率 网络服务和数据的备份 备份 备份策略 备份频率 网络服务和数据的备份

  9. 华为服务器本地备份系统,服务器系统备份方案

    服务器系统备份方案 内容精选 换一换 随着最近几年曝出的各种"门"事件,国产软件厂商有面临产品后门和特殊时刻被停止授权的风险,对于基础软件之一的数据库软件急需有行之有效的替代方案. ...

最新文章

  1. 机器人 Ameca「苏醒」瞬间逼真到令人恐惧,网友纷纷惊叹……
  2. 使用XML创建Excel文档
  3. java-println连接
  4. oracle重做日志文件版本不一致问题处理
  5. Android之內置、外置SDCard
  6. python之各种装饰器的使用
  7. BayaiM__SQLLDR_linux_shell高级版
  8. python科学计算与可视化教程
  9. 3说明书_怎么才能做好产品说明书翻译?知行翻译公司总结了3点
  10. 微软十月补丁星期二值得关注的0day及其它
  11. 《游戏设计师修炼之道:数据驱动的游戏设计》一1.4 来自政府和产业的挑战...
  12. 依赖注入原理,作用,注入方式——Spring IOC/DI(二)
  13. 高等数学张宇18讲 第十四讲 数学一、数学二专题内容
  14. 分享11款Steam推理游戏
  15. Lipschitz 条件或者Lipschitz连续
  16. 简单的创建app id 的流程
  17. android property实现路径
  18. 【300+精选大厂面试题持续分享】大数据运维尖刀面试题专栏(九)
  19. ECS开发(一、)ECS是什么?
  20. 浪漫的小王子是王德华

热门文章

  1. RecyclerView --- 分割线
  2. Python中zip函数的用法
  3. 龙ol服务器维护补偿boss,龙OL副本BOOS位置攻击属性及掉落物品介绍
  4. 复合型网络拓扑结构图_网络拓扑结构大全和图片(星型、总线型、环型、树型、分布式、网状拓扑结构)....
  5. Image Thresholding图像阙值化和Adaptive Thresholding
  6. qpython androidhelper gps_Qpython SL4A获取手机电量和GPS
  7. oracle 18c ad登陆,Oracle 18c PSU
  8. 怎 样 寻 找 安 全 漏 洞 (转)
  9. Hadoop IO 特性详解(1)【数据完整性】
  10. 回忆童年游戏之棋盘决奕