rman技术
Rman备份与恢复总结一.Rman备份
1.1 Rman介绍
1-> Rman信息库可以存放在两个位置
目标数据库控制文件
恢复目录(recovery catalog)
控制文件里面存放的记录分为两类
1.可以删除的记录(归档日志文件的历史记录及Rman备份的元数据)
2.不可删除的记录(数据文件、联机日志文件列表等)
如果需要在控制文件中存放新的记录,则可以删除那些可以删除的部分,从而提供可用的空,
注意:如果Rman备份的元数据被删除,Rman的备份的数据就失去了意义,因此Rman备份的元数据很重要。
2->备份的时间间隔
可以通过设置初始化参数--controlfile_record_keep_time--来决定控制文件中可以删除部分,默认是7天,表示控制文件可以保存近7天的可删除文件记录,如果设置为0,表示不删除历史记录,那么控制文件的增长将会失去控制(空间不够),因此Rman的备份周期不能超过7天。
--查看时间间隔
#Sqlplus / as sysdba
Sql>Show parameters control
3->控制文件的自动备份
控制文件的自动备份功能从oracle 9i引入,简化了控制文件的备份
Rman>configure controlfile autobackup on;
这里控制文件自动备份时,控制文件的备份路径查看 show all
注意:configure controlfile autobackup format for device type disk to ‘%F’; 路径应为disk磁盘
4->Rman备份的内容和顺序
A. 数据库数据文件
B. 归档日志文件
C. 控制文件
D. 参数文件
案例:
$ rman target / log /tmp/rman_full.log--指定好日志输出文件可以明确备份过程
RMAN> run
2> {
3> allocate channel c1 type disk;
4> allocate channel c2 type disk;
5> backup database filesperset 2 format '/oracle/full_%d_%T_%s_%p';
6> sql 'alter system archive log current';
7> sql 'alter system archive log current';
8> backup archivelog all format '/oracle/arch_%d_%T_%s_%p' delete input;
9> backup current controlfile formate '/oracle/ctl_%d_%T_%s_%p';
10>}
注意:如果是先备份控制文件在备份日志文件,在恢复数据库的时候会发现找不到日志文件
如果是先备份了控制后备份了日志,恢复过程中的操作--(需要有日志输出文件,可以查看到日志文件在哪里)
恢复过程中出现
处理过程。。找到日志文件所在目录
Rman> catalog backuppiece ‘/oracle/arch_..._20140607_6_1’;--注意要将所以的归档日志都catalog 才能正常的恢复数据库,有那些归档日志可以查看日志的输出文件(体现出日志输出文件的重要性)
Rman>recover database;
1.2 Rman备份脚本的书写
1.2.1备份脚本格式图
1.2.2 Rman备份脚本-全库
ExportORACLE_SID=zytk35
ExportORACLE_HOME=/ora/app/oracle/product/11.2.0/dbhome_1
ExportPATH=$ORACLE_HOME/bin:$PATH
Rman target/ log /tmp/rman_full.log append <<EOF--append方式是追加的意思
Run
{
CONFIGURE RETENTION POLICY TO RECOVERY WINDOW OF 7 DAYS;
----将备份保留7天,过期则自动删除
Allocate channel c1 type disk;--分配磁盘通道,如果压力不大可以多分配,分配的通道越多,对硬盘的I/0压力越大,
Allcoalte channel c2 type disk;
Backup database filesperset 4 format ‘/oracle/full_%d_%T_%s_%p’;
---filesperset备份集文件,多分配通道,备份集少的话可以快速回复
Sql ‘alter system archive log current’;
Backup archivelog all format ‘/oracle/arch_%d_%T_%s_%p’ delete input; --把当前备份好的归档删除
Backup current controlfile format ‘/oracle/ctl_%d_%T_%s_%p’;
delete archivelog until time "sysdate - 7";--删除7天前的归档日志
}
EOF
可以将该脚本编辑成.sh文件,可以直接在linux下执行。
1.2.3备份脚本-归档
ExportORACLE_SID=zytk35
ExportORACLE_HOME=/ora/app/oracle/product/11.2./dbhome_1
ExportPATH=$ORACLE_HOME/bin:$PATH
Rman target / log /tmp/rman_arch.log append<<EOF
Run
{
Allocate channel c1 type disk;
Allocate channel c2 type disk;
Sql ‘alter system archive log current’;
Backup archivelog all format ‘/oracle/arch_%d_%T_%s_%p’; delete input;
Backup current controlfile formt ‘/oracle/ctl_%d_%T_%s_%p’;
}
EOF
注意:归档日志满了,可以用下面命令校验归档日志
Rman>crosscheck archivelog all;
1.2.4 oracle冗余策略
指oracle数据库备份时保留下来的备份文件删除策略
1.Recovery window
哪些文件必须备份?默认值是7
留下来的备份,必须能够将数据库恢复到指定的时间内的任意一个时刻,指定这个参数为7,则表示保留的备份文件可以将数据库恢复到最近7天中的任何一个时刻。
2.Redundancy
表示要保留的,能够将数据库恢复到最新状态的完整的备份文件的个数。根据策略,不在需要的备份文件则被认为是obsolete。
脚本:
Export ORACLE_SID=zytk35
Export ORACLE_HOME=/ora/app/oracle/product/11.2.0/db_home
Export PATH=$ORACLE_HOME/bin:$PATH
Rman target /log /tmp/rman_delete.log append <<EOF
Run
{
Allocate channel for maintenance type disk;--指磁盘通道
Allocate channel for maintenance type sbt_tape;--磁带通道
Crosscheck archivelog all;--校验归档日志
Crosschenk backup; --备份归档日志
Delete noprompt obsolete;--删除冗余
EOF
}
删除备份脚本总结:
rman的删除语句如下:
run {
delete noprompt obsolete;
crosscheck backup;
delete noprompt expired backup;
crosscheck archivelog all;
delete noprompt expired archivelog all;
delete noprompt archivelog all completed before 'SYSDATE - 7';
}
1.2.5备份方案
全库备份脚本
run{
allocate channel c1 type disk;
allocate channel c2 type disk;
allocate channel c3 type disk;
backup full tag 'dbfull' format '/u01/oradata/backup/full%u_%s_%p' database
include current controlfile;
sql 'alter system archive log current';
backup fileaperset 3 format '/u01/oradata/backup/arch%u_%s_%p'
archivelog all delete input; #备份归档可选,可以单独定期备份
release channel c1;
release channel c2;
release channel c3;
}
零级备份脚本
run{
allocate channel c1 type disk;
allocate channel c2 type disk;
allocate channel c3 type disk;
backup incremental level 0 tag 'db0' format '/u01/oradata/backup/db0%u_%s_%p'
database skip readonly;
sql 'alter system archive log current';
backup fileaperset 3 format '/u01/oradata/backup/arch%u_%s_%p'
archivelog all delete input; #备份归档可选,可以单独定期备份
release channel c1;
release channel c2;
release channel c3;
}
一级备份脚本
run{
allocate channel c1 type disk;
allocate channel c2 type disk;
allocate channel c3 type disk;
backup incremental level 1 tag 'db1' format '/u01/oradata/backup/db1%u_%s_%p'
database skip readonly;
sql 'alter system archive log current';
backup fileaperset 3 format '/u01/oradata/backup/arch%u_%s_%p'
archivelog all delete input; #备份归档可选,可以单独定期备份
release channel c1;
release channel c2;
release channel c3;
}
1.星期天晚上 -level 0 backup performed(全备份)
2.星期一晚上 -level 2 backup performed
3.星期二晚上 -level 2 backup performed
4.星期三晚上 -level 1 backup performed
5.星期四晚上 -level 2 backup performed
6.星期五晚上 -level 2 backup performed
7.星期六晚上 -level 2 backup performed
如果星期二需要恢复的话,只需要1+2,
如果星期四需要恢复的话,只需要1+4,
如果星期五需要恢复的话,只需要1+4+5,
如果星期六需要恢复的话,只需要1+4+5+6.
二.Rman恢复
2.1 自动控制文件备份没有打开--(备份到磁盘上)
Rman target / log /tmp/rman_control.log append <EOF
Run
{
Allocate channel c1 type disk;
Restore controlfile ‘/oracle/control_backup_set’;--指定到控制文件可以查看输出归档日志
EOF
}
2.2自动控制文件备份没有打开--(备份到磁带上)
Rman target / log /tmp/rman_control.log append <EOF
Run
{
Allocate channel c1 type sbt_tape;
Restore controlfile from ‘ctl_.......’;指定路径下的控制文件
EOF
}
2.3 自动控制文件备份打开(默认位置)从磁盘恢复
Rman target /
Rman>configure controlfile autobackup on;
Rman>conigure controlfile autobackup format for device type disk to ‘%F’;
数据库恢复:
Rman target /nocatalog
Rman>
Run
{
Allcoate channel c1 type disk;
Restore controlfile from auto backup;
}
2.4 自动控制文件备份打开(非默认位置)从磁盘恢复
Rman target /
Rman>configure controlfile autobackup on;
Rman>conigure controlfile autobackup format for device type disk to ‘/oracle/%F’;
数据库恢复:
Rman target /nocatalog
Rman>
Run
{
conigure controlfile autobackup format for device type disk to ‘/oracle/%F’;
Restore controlfile from auto backup;
}
详细的各种数据库文件损坏恢复查看《Rman恢复》文档
{:soso_e179:} 不错 写的很详细
页:
[1]