--====================
-- RMAN 还原与恢复
--====================
在 Oracle 中,三大文件即控制文件,数据文件,日志文件的丢失与破坏都将需要使用还原或恢复来使数据库正常化。而 RMAN 还原与恢复
是实现数据库完整性、可靠性必不可少的手段之一。还原简言之即是将所需的文件从备份中复制到原来文件所在的路径。还原通常可以包括
数据库、表空间、数据文件级别的还原。通常还原后的内容会滞后于最新的数据库 SCN ,因此将归档日志、联机重做日志文件中的内容更新到
还原的数据文件中,这个过程称之为恢复。
恢复的几种情形
1. 在 mount 或 open 阶段完成的灾难恢复
非系统表空间, undo 表空间,所有的数据文件
2. 在 nomount 阶段完成的灾难恢复
控制文件 (controlfile)
3. 在 mount 阶段完成的灾难恢复
系统表空间,联机重做日志文件
有关恢复、介质恢复、一致性或非一致性恢复的详细概念请参考: Oracle 基于用户管理恢复的处理
一、 RMAN 在归档模式下的还原与恢复的简化例子
RMAN > connect target /
RMAN > startup mount ;
RMAN > restore database ;
RMAN > recover database ;
RMAN > alter database open ;
二、使用 RMAN 进行还原与恢复 ( 非 catalog 方式 )
1. 数据文件丢失的恢复处理
-- 设定客户端环境变量并连接到数据库
C : / > set NLS_LANG = AMERICAN_AMERICA . AL32UTF8
C : / > rman target sys / redhat@dedicated nocatalog
-- 对数据库做全备
RMAN > backup as backupset
2 > format '/u01/bk/rmbk/wb_%U'
3 > tag = Whole_bak database ;
RMAN > sql 'alter system archive log current' ;
-- 对数据库做级增量备份
RMAN > run{
2 > allocate channel ch1 type disk ;
3 > backup incremental level 0 database
4 > format '/u01/bk/rmbk/Inc_0_%U'
5 > tag = Inc_0 ;
6 > release channel ch1 ;}
-- 对表插入新记录并切换日志
SQL > select * from tb2 ;
ID NAME
---------- ---------------------------------------------
1 Robinson
2 Henry
SQL > insert into tb2 select 3 , 'Danny' from dual ;
SQL > commit ;
SQL > alter system checkpoint ;
SQL > alter system switch logfile ;
-- 对数据库做级增量备份
RMAN > run{
2 > allocate channel ch1 type disk ;
3 > backup incremental level 1 database
4 > format '/u01/bk/rmbk/Inc_1%U'
5 > tag = Inc_1 ;
6 > release channel ch1 ;}
SQL > shutdown immediate ; -- 关闭数据库
SQL > ho rm $ORACLE_BASE / oradata / orcl /*.dbf -- 删除所有的数据文件 */
SQL > startup mount
-- 使用 RMAN 连接到未 mount 状态的数据库
RMAN > connect target sys / redhat@dedicated
connected to target database : ORCL ( DBID = 1257415066 , not open )
-- 执行数据库还原
-- 注意当存在完整备份也同时存在级增量备份时, Oracle 会自动使用级增量备份来还原数据库
RMAN > restore database ;
piece handle =/ u01 / bk / rmbk / Inc_0_0alqu132_1_1 tag = INC_0 -- 下面可以看出还原的数据来自级增量备份
-- 执行数据库恢复
RMAN > recover database ;
piece handle =/ u01 / bk / rmbk / Inc_10clqu1fe_1_1 tag = INC_1
-- 打开数据库验证恢复
RMAN > alter database open ;
SQL > select * from bk . tb2 ;
ID NAME
---------- ---------------------------------------------
1 Robinson
2 Henry
3 Danny
2. 磁盘损坏导致数据文件无法恢复到原始位置或不想恢复到原始位置的处理
使用 set newname 命令将数据文件还原到新路径
set newname for datafile 1 to '<newdir>/system01.dbf' ; -- 为恢复的数据文件指定新路径或重命名
使用 switch 命令将变更更新到控制文件
switch datafile n | all ; -- 等同于 alter database rename file 命令,该命令将恢复的数据文件重命名更新到控制文件
-- 下面的示例首先删除 tbs01.dbf ,接下来将其恢复到 oradata 目录中
SQL > ho rm $ORACLE_BASE / oradata / orcl / tbs01 . dbf
SQL > startup mount force ;
RMAN > connect target sys / redhat@dedicated
connected to target database : ORCL ( DBID = 1257415066 , not open )
RMAN > run{
2 > set newname for datafile 6 to '/u01/app/oracle/oradata/tbs01.dbf' ;
3 > restore database ;
4 > switch datafile all;
5 > recover database ;
6 > alter database open ;}
SQL > select file# , name , status from v$datafile where file# = 6 ;
FILE# NAME STATUS
---------- -------------------------------------------------- -------
6 / u01 / app / oracle / oradata / tbs01 . dbf ONLINE
SQL > select count ( 1 ) from bk . tb2 ; -- 表 tb2 位于 tbs01.dbf 内
COUNT ( 1 )
----------
3
3. 恢复表空间
-- 删除表空间内的数据文件,删除后在针对位于该表空间的表进行插入记录以及实施检查点进程
SQL > ho rm $ORACLE_BASE / oradata / tbs01 . dbf
SQL > insert into bk . tb2 select 4 , 'Jackson' from dual ;
SQL > commit ;
SQL > alter system checkpoint ;
-- 强制检查点后,告警日志出现错误提示,视图 v$recover_file 给出了故障数据文件
[oracle@oradb ~]$ tail - n 50 $ORACLE_BASE / admin / orcl / bdump / alert_orcl . log
Errors in file / u01 / app / oracle / admin / orcl / bdump / orcl_ckpt_4724 . trc :
ORA - 01110 : data file 6 : '/u01/app/oracle/oradata/tbs01.dbf'
ORA - 01116 : error in opening database file 6
ORA - 01110 : data file 6 : '/u01/app/oracle/oradata/tbs01.dbf'
ORA - 27041 : unable to open file
Linux Error : 2 : No such file or directory
SQL > select * from v$recover_file ;
FILE# ONLINE ONLINE_ ERROR CHANGE# TIME
---------- ------- ------- ------------------ ---------- ---------
6 OFFLINE OFFLINE FILE NOT FOUND 0
SQL > select name , status from v$datafile where file# = 6 ;
NAME STATUS
-------------------------------------------------- -------
/ u01 / app / oracle / oradata / tbs01 . dbf RECOVER
-- 使用 RMAN 命令恢复数据文件,此时数据库处于 OPEN 状态,因此首先需要将表空间脱机,恢复完成之后再将其联机
RMAN > run{
2 > sql 'alter tablespace tbs1 offline immediate' ;
3 > set newname for datafile 6 to '/u01/app/oracle/oradata/orcl/tbs01.dbf' ;
4 > restore tablespace tbs1 ;
5 > switch datafile all;
6 > recover tablespace tbs1 ;
7 > sql 'alter tablespace tbs1 online' ;}
SQL > select name , status from v$datafile where file# = 6 ; -- 位置变动到 orcl 子目录下,状态变为 online
NAME STATUS
-------------------------------------------------- -------
/ u01 / app / oracle / oradata / orcl / tbs01 . dbf ONLINE
-- 也可以使用下面的命令完成同样的功能
-- 注意如果表空间内有多个数据文件,而仅有单个数据文件损坏则采用下面的方式处理更为妥当
RMAN > run{
2 > sql 'alter database datafile 6 offline immediate' ;
3 > set newname for datafile 6 to '/u01/app/oracle/oradata/tbs01.dbf' ;
4 > restore datafile 6 ;
5 > switch datafile all;
6 > recover datafile 6 ;
7 > sql 'alter databaes datafile 6 online' ;}
4.RMAN 实现不完全恢复
对于 RMAN 的不完全恢复,使用 Oracle 的闪回特性的处理有更多的优势。关于闪回请参考: Oracle 闪回特性
步骤
a . 加载数据到 mount 状态 ( 建议恢复前先做备份 )
b . 为高并发分配多个通道
c . 还原所有 ( 所需 ) 的数据文件
d. 使用 until time,until sequence,until scn 来恢复数据库
e. 使用 resetlogs 打开数据库
f . 全备数据库
演示 RMAN 基于 until time 的例子
SQL > show user ;
USER is "BK"
SQL > create table tb1 ( id int , name varchar2 ( 10 ));
SQL > insert into tb1 select 1 , 'Lancy' from dual ;
SQL > ho strings $ORACLE_BASE / oradata / orcl / redo02 . log | grep Lancy -- 查看联机日志文件中不存在刚刚插入的记录
SQL > commit ; -- 注意 commit 是将日志缓冲内容写入到日志文件
SQL > ho strings $ORACLE_BASE / oradata / orcl / redo02 . log | grep Lancy -- 提交后联机日志文件中才有新增的记录
Lancy
SQL > alter system switch logfile ;
SQL > ho ls $ORACLE_BASE / oradata / arch
log_1_1_732989230 . arc log_1_1_732989889 . arc
RMAN > run{
2 > allocate channel ch1 type disk ;
3 > allocate channel ch2 type disk ;
4 > backup as compressed backupset database plus archivelog delete input
5 > format '/u01/bk/rmbk/wh_lg_%U'
6 > tag = 'Wholebak_Pluslog' ;
7 > release channel ch1 ;
8 > release channel ch2 ;}
18 : 10 : 36 SQL > drop table tb1 ;
RMAN > run{
2 > allocate channel ch1 type disk ;
3 > allocate channel ch2 type disk ;
4 > set until time "to_date('2010-10-21 18:10:36','yyyy-mm-dd hh24:mi:ss')" ;
5 > restore database ;
6 > recover database ;
7 > alter database open resetlogs ;
8 > release channel ch1 ;
9 > release channel ch2 ;}
SQL > select * from tb1 ;
ID NAME
---------- ----------
1 Lancy
5. SPFILE 文件丢失的恢复
SPFILE 参数文件可以在 RMAN 中进行备份,因此可以使用 RMAN 来恢复 SPFILE 文件。可以自动备份 SPFILE 。
SPFILE 的自动备份是随着控制文件的备份一起被完成的,因此可以通过自动备份控制文件来实现自动备份 SPFILE 文件的目的
其次,在备份系统表空间时将引发控制文件的自动备份,而不论是否设置自动备份参数为 ON ,此时同样也备份 SPFILE 文件
有关 SPFILE 文件请参考: Oracle 参数文件
SPFILE 文件恢复步骤
a. startup nomount [force];
b. set dbid=dbid_no;
c. restore spfile from autobackup | '<dir>'
d. startup force; 如果 d 执行失败则转到 e , f ,否则不用执行 e , f 。
e. set dbid=dbid_no;
f. startup;
下面设定控制文件的自动备份以及设置其备份路径 ( 注意要预先知道目标数据库的 DBID ,此次演示的 DBID 为 )
RMAN > configure controlfile autobackup on ;
RMAN > configure controlfile autobackup format for device type disk to '/u01/bk/rmbk/auto_ctl_%d_%F' ;
RMAN > exit
sys@ORCL > alter tablespace users add datafile '$ORACLE_BASE/oradata/orcl/users02.dbf' size 5m ;
[oracle@oradb rmbk]$ ls auto * -- 执行上一条 alter tablespace users add datafile 语句将引发控制文件的自动备份
auto_ctl_ORCL_c - 1263182651 - 20101124 - 00
sys@ORCL > shutdown immediate ;
[oracle@oradb dbs]$ mv spfileorcl . ora spfileorcl . ora . bak -- 将原来的 spfile 文件重命名
[oracle@oradb ~]$ rman target / nocatalog
RMAN > startup nomount force ;
RMAN > set dbid = 1263182651 ;
RMAN > restore spfile from autobackup ; -- 此处并没有找到文件路径,按 Oracle 联机文档,在 nomount 状态应该可以找到
RMAN - 06172 : no autobackup found or specified handle is not a valid copy or piece
RMAN > restore spfile from '/u01/bk/rmbk/auto_ctl_ORCL_c-1263182651-20101124-00' ; -- 手动指定路径
RMAN > startup force ;
6. 联机重做日志文件丢失的恢复请参考:
基于 catalog 的 RMAN 备份与恢复
Oracle 联机重做日志文件(ONLINE LOG FILE)
7. 控制文件的恢复处理
控制文件中描述了数据库的相关物理信息,如创建时间、 DBID 、数据文件、日志文件等相关信息,因此一旦控制文件丢失数据库将
不能启动,鉴于其重要性,控制文件的备份与恢复将单独列出。有关控制文件请参考下列
基于 catalog 的 RMAN 备份与恢复
Oracle 控制文件的备份与恢复
三、更多参考
有关基于用户管理的备份和备份恢复的概念请参考:
Oracle 基于用户管理恢复的处理 ( 详细描述了介质恢复及其处理 )
有关 RMAN 的恢复与管理请参考:
RMAN 还原与恢复
有关 Oracle 体系结构请参考:
Oracle 实例和Oracle 数据库(Oracle 体系结构)
Oracle 联机重做日志文件(ONLINE LOG FILE)