执行完全恢复:在 ARCHIVELOG 模式下 丢失了系统关键数据文件:
如果某个数据文件丢失或损坏,且该文件属于 SYSTEM 或 UNDO 表空间,请执行以下步骤:
1.
实例可能会也可能不会自动关闭。
2.如果未自动关闭,请使用 SHUTDOWN ABORT 关闭实例。
3.
装载数据库。
4.
还原并恢复缺失的数据文件。
5.打开数据库。
1.归档模式丢失非关键数据文件 完全恢复
第一种方法:
shutdown abort;
startup mount;
alter database create datafile '/home/oracle/test.dbf' as '/home/oracle/test.dbf';
recover datafile;
第二种方法:
create tablespace test datafile '/home/oracle/test.dbf' size 10m;
rman target /
backup datafile 5;
rm test.dbf
sq> alter database datafile 5 offline;
restore datafile 5;
recover datafile 5;
sq> alter database datafile 5 online;
select FILE#,STATUS from v$datafile;
2. 归档模式丢失关键数据文件 完全恢复
利用备份,同上第二种方法。
--------------------------------------------------------------------------------------------------------------
恢复映像副本:
RMAN> recover copy of database with tag 'daily_inc';
RMAN> backup incremental level 1 for recover of copy
with tag 'daily_inc' database;
RECOVER BACKUP
第 1 天 无 创建映像副本
第 2 天 无 创建 1 级增量备份
第 3 天和以后 根据增量备份恢复副本 创建 1 级增量备份
恢复映像副本:示例
如果每天都运行以上命令,则可以随时获得所有数据库数据文件的连续更新的映像副本。
图表显示了每次运行所发生的操作。请注意,这种算法需要一段准备期间;到第 3 天后策略才会起作用。
第 1 天
RECOVER 命令没有执行任何操作。尚不存在要恢复的映像副本。BACKUP 命令可用于创建映像副本。
第 2 天
RECOVER 命令仍没有执行任何操作。因为尚不存在增量备份。由于已在第 1 天创建了基准映像副本,BACKUP 命令会创建增量备份。
第 3 天
RECOVER 命令将增量备份中的更改应用于映像副本。BACKUP 命令将执行另一个增量备份,该备份将在第 4 天用于恢复映像副本,依此进行循环。
执行到映像副本的快速切换
执行以下步骤
可以使用数据文件的映像副本进行快速恢复:
1.使数据文件脱机。
2.使用 SWITCH TO ...COPY 命令指向这些文件的映像副本。
3.恢复数据文件。
4.使数据文件联机。
此时,数据库是可用的,且数据文件已恢复。但是,如果您希望将数据文件放回其原始位置,请继续执行以下步骤:
5.使用 BACKUP AS COPY 命令在原始位置创建数据文件的映像副本。
6.使数据文件脱机。
7.使用 SWITCH TO COPY 命令切换到在步骤 5 中创建的副本。
8.恢复数据文件。
9.使数据文件联机。
可以使用此命令来恢复数据文件、表空间、临时文件或整个数据库。切换到的目标文件必须为映像副本。
3. 映像副本的快速切换
backup as copy datafile 6;
rm a.dbf
sql:alter database datafile 6 offline;
rman >switch datafile '/home/oracle/test.dbf' to copy;
recover datafile 6;
--回复后数据文件的路径和名称为 '/home/oracle/test.dbf';
alter database datafile 4 online;
select FILE#,STATUS from v$datafile;
select file_name from dba_data_files;
backup as copy datafile 4 format '/u01/app/oracle/oradata/orcln/users01.dbf';
alter database datafile 4 offline;
switch datafile ' /home/oracle/backup/db_data_D-ORCL_I-4115975543_TS-TEST_FNO-6_38otbf5q.bak' to copy;
switch datafile 4 to copy;
recover datafile 4;
alter database datafile 4 online;
select file_name from dba_data_files;
-----------------------------------------------------------------------------------------------------------------
4. set newname 改名字
backup as copy datafile 6;
list copy of datafile 6;
select FILE#,STATUS from v$datafile;
run{
allocate channel c1 device type disk;
sql "alter database datafile 6 offline";
set newname for datafile '/home/oracle/test.dbf' to '/home/oracle/test_new.dbf';
restore datafile 6;
switch datafile all;
recover datafile 6;
sql "alter database datafile 6 online";
}
--------------------------------------------------------------------------------------------------------------
从自动备份还原控制文件:
RMAN> STARTUP NOMOUNT;
RMAN> RESTORE CONTROLFILE FROM AUTOBACKUP;
RMAN> ALTER DATABASE MOUNT;
RMAN> RECOVER DATABASE;
RMAN> ALTER DATABASE OPEN RESETLOGS;
7. 丢失控制文件,参数文件 --数据库必须在nomount状态
查看文件信息:
SQL>select name from v$controlfile;
SQL>show parameter spfile;
SQL> select name from v$datafile;
配置控制文件自动备份恢复控制文件
rman target /
connected to target database: ORCL (DBID=1353286769)
RMAN>show all;
RMAN