svnadmin dump备份工具

转载 2016年05月30日 11:21:02

转载:http://blog.itpub.net/23141985/viewspace-713631/

作者:kidking2010

svnadmin dump备份工具(转载)

(

svn

备份

分类: svn学习笔记

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

关闭所有运行的进程,并确认没有程序在访问存储库(如 httpd、svnserve 或本地用户在直接访问)。

备份svn存储库

#压缩备份
svnadmin dump /home/workhome/svn/repository | gzip > ~/repository-backup.gz
#不压缩备份
svnadmin dump /home/workhome/svn/repository > ~/repository-backup.svn

恢复svn存储库

#建立新的svn存储库
svnadmin create /home/workhome/svn/newrepository
#确认成功与否
ls -l /home/workhome/svn/newrepository
#导入存储库数据
svnadmin load /home/workhome/svn/newrepository < ~/repository-backup.svn

或者采用一定的备份策略:
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 $youngestn";
my $svnadmin_cmd="svnadmin dump--revision $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 -9 $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 = ;
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 dump备份工具

这是subversion官方推荐的备份方式。 关闭所有运行的进程,并确认没有程序在访问存储库(如httpd、svnserve 或本地用户在直接访问)。 备份svn存储库 #压缩备份 s...

SVN使用svnadmin dump进行备份时报“拒绝访问”错误

svnadmin dump进行备份时报“拒绝访问”错误的解决方法,网上查阅的大多数都是说文件系统错误,自己遇到的情况与网上的不同,就把这个问题和解决方法分析给大家吧...

dump、cpio、tar、dd四种备份工具比较

dump dump可执行文件系统增量备份的存储操作,dump 可将目录或整个文件系统备份至指定的设备,或备份成一个大文件。dump 可以执行类似 tar 的功能。然而,dump 倾向于考虑文件系统而不...

第九章 完整备份工具:dump, restore

完整备份工具:dump 某些时刻你想要针对文件系统进行备份或者是储存的功能时,不能不谈到这个 dump 命令! 这玩意儿我们曾在前一章的 /etc/fstab 里面稍微谈过。 其实这个命令除了能够针...

MySQL 5.5 DBA工具 多进程dump 多进程load 多进程备份还原 python 脚本

mysqldump 目前只支持但线程dump,物理备份innodb因为额ibdata又有天生的缺陷,例如将一个实例中的某个库导入到另一个实例中,就比较麻烦了。 所以写了这套脚本。 适用场景: 1...
  • ylqmf
  • ylqmf
  • 2012年09月18日 22:11
  • 6924

svn库迁移-备份和恢复-svnadmin

文章转载来自:http://blog.sina.com.cn/s/blog_5eb1a2670100l24i.html   前段时间对项目SVN库做整理, 顺带再次研究了下SVN迁移的方式...

PostgreSQL pg_dump&psql 数据的备份与恢复

Usage: pg_dump [OPTION]… [DBNAME] 数据库名放最后,不指定默认是系统变量PGDATABASE指定的数据库。General options:(一般选项)-f, –f...
  • DB_su
  • DB_su
  • 2017年11月09日 16:36
  • 94

postgresql使用pg_dump备份与恢复

postgresql使用pg_dump备份与恢复pg_dump备份范例pg_dump -F c -Z 5 -v -t rpt_df580_bh_funnel -f "/home/postgres/...
  • db_guy
  • db_guy
  • 2016年12月28日 16:43
  • 182

mysql dump备份方式 mysql还原操作练习

环境:centos 6.5  mysql:mysql 5.1.65 6.1.73  该命令适用于 5.6.25。 备份:mysqldump 备份MySQL数据库的命令 mysqldum...

PostgreSQL pg_dump&psql 数据的备份与恢复

参考:http://blog.chinaunix.net/uid-354915-id-3504632.html [root@localhost postgres-9.3.5]# pg_dump ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:svnadmin dump备份工具
举报原因:
原因补充:

(最多只允许输入30个字)