Oracle数据库完全恢复和不完全恢复以及执行用户(2)

2.执行用户管理的数据库恢复

1)执行用户管理的数据库完全恢复

用户管理的数据库完全恢复:

将数据库恢复到最新的 SCN

可以一次处理整个数据库,也可以一次处理一个数据文件或表空间 需要当前控制文件 需要有待恢复的所有文件的备份 需要到目前为止的所有归档日志

V$RECOVER_FILE:查看哪些文件需要介质恢复

V$RECOVERY_LOG:查看执行恢复需要哪些归档日志

在某些情况下,属于 SYSTEM 表空间的文件受到损坏时,实例将自动关闭。当某些数据文件有问题时,即使实例保持运行状态,您也可以判定使数据库保持运行状态没有任何意义;受影响的数据库对象太多了。在这种情况下,请关闭数据库执行恢复。

如果数据库仍处于打开状态,则可以查询 V$RECOVER_FILE 视图了解哪些数据文件需要恢复,并查询 V$RECOVERY_LOG 了解需要哪些归档日志。这会指示您需要从备份中还原哪些文件(如果有)。

然后关闭数据库。调查介质故障,确定问题原因。修复该问题,以便可以从备份中还原文件。

例如,您可能需要更换磁盘驱动器。

现在,可使用 RECOVER 命令来执行恢复。将恢复范围限制在所需范围,如数据文件或表空间。如果需要,可恢复整个数据库。随后,打开数据库。

SQL> SELECT file#, error FROM v$recover_file;

--确定需要恢复的数据文件

SQL> SELECT archive_name FROM v$recovery_log;

--确定完成恢复所需的归档日志文件

确定与恢复相关的文件

如果数据库仍处于打开状态,请按下面的说明查询文件。否则,请尝试启动实例,并装载数据库发出查询。

为了确定哪些数据文件需要恢复,查询 V$RECOVER_FILE 视图。ERROR 列指明文件需要恢复的原因。如果此列具备 OFFLINE NORMAL 以外的任何值,则需要恢复。

要查看所有受影响的数据文件和表空间的概况,可以在此查询中加入 V$DATAFILE 和 V$TABLESPACE。

下面是一个示例:

SELECT r.FILE# ,d.NAME df_name ,t.NAME tbsp_name, d.STATUS ,r.ERROR ,r.CHANGE# ,r.TIME

FROM  V$RECOVER_FILE r, V$DATAFILE d, V$TABLESPACE t

WHERE  t.TS# = d.TS#

AND    d.FILE# = r.FILE#;

这可指示受损的程度,帮助您确定 RECOVER 命令的对象。

V$RECOVERY_LOG 视图显示执行恢复所需的归档日志文件。如果列表显示某些文件已移出默认归档日志位置,则必须将它们还原到某个位置,再执行恢复。

记录这些查询的结果后,关闭数据库。

还原与恢复相关的文件

确定了需要哪些数据文件和归档日志文件后,将它们还原到相应的磁盘位置。通过从备份位置复制数据文件,可以还原该数据文件,如以下示例所示:

$ cp /disk2/backup/datafile/survey01.dbf  $Oracle_BASE/oradata/ORCL/datafile/survey01.dbf

如果恢复需要任何归档日志,检查这些日志是否仍位于归档日志的默认磁盘位置。这些日志可能不在默认位置,

例如,已将它们移至磁带或其它磁盘驱动器。如果日志已被移动,则需将它们还原到默认归档日志位置或临时位置。如果默认位置(由 LOG_ARCHIVE_DEST_1 初始化参数指定)中有足够的可用空间,在该位置还原日志。否则,可以将日志置于某个其它磁盘位置。还原时,可指定该备用位置来查找归档日志文件。

如果需要移动数据文件,则必须将这一情况记录在控制文件中。通过执行 ALTER DATABASE RENAME FILE 命令,可以完成此操作,如下例所示:

SQL> ALTER DATABASE RENAME FILE

'/u01/app/oracle/oradata/ORCL/datafile/survey01.dbf' TO

'/newdisk/ORCL/datafile/survey01.dbf';

--须先启动实例并装载数据库,然后才能执行 ALTER DATABASE RENAME FILE 命令。

载数据库并使所有数据文件联机(如果尚未执行此操作)。通过查询 V$DATAFILE 视图,可以检查每个数据文件的状态。可使用如下命令使数据文件联机:

SQL> ALTER DATABASE DATAFILE  '/newdisk/ORCL/datafile/survey01.dbf' ONLINE;

应用重做数据

此时,数据文件已还原到过去的某个时间点。归档日志文件也已还原到其默认位置或某个其它位置(仅用于此恢复)。已准备就绪,可执行真正的恢复步骤,这意味着已应用重做且数据文件已恢复到最新 SCN。

使用 SQL*Plus RECOVER 命令执行此操作。

如果没有指定 AUTOMATIC 选项,则系统会提示您指定要应用的每个重做日志文件。这样可以提高对恢复过程的控制。通常,AUTOMATIC 用于完全恢复。

如果归档日志文件已还原到数据库默认位置以外的某个磁盘位置,则必须指定 FROM 子句。提供存储这些文件的目录,恢复过程将在该目录中寻找文件。

最后,打开数据库。此时已完全恢复。

SQL> RECOVER AUTOMATIC FROM '/u01/arch_temp' DATABASE;

--使用 RECOVER 命令应用重做数据

SQL> ALTER DATABASE OPEN;    --打开数据库

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/1cacafa5140efc841bac8e56c75d64a4.html