正确答案:D
一、模拟上题的错误:
1、删除4号文件
- [oracle@mydb~]$cd/u01/app/oracle/oradata/ocm/
- [oracle@mydbocm]$rm-rfusers01.dbf
2、数据库宕机
- sys@OCM>shutdownabort;
- ORACLEinstanceshutdown.
3、启动数据库报错,与上题报错一样
- sys@OCM>startup
- ORACLEinstancestarted.
- TotalSystemGlobalArea839282688bytes
- FixedSize2233000bytes
- VariableSize583011672bytes
- DatabaseBuffers247463936bytes
- RedoBuffers6574080bytes
- Databasemounted.
- ORA-01157:cannotidentify/lockdatafile4-seeDBWRtracefile
- ORA-01110:datafile4:'/u01/app/oracle/oradata/ocm/users01.dbf'
4、如果试图在没有执行advise failure命令时使用repair failure命令,将出现如下错误:
- [oracle@mydb~]$rmantarget/
- RMAN>repairfailure;
- usingtargetdatabasecontrolfileinsteadofrecoverycatalog
- RMAN-00571:===========================================================
- RMAN-00569:===============ERRORMESSAGESTACKFOLLOWS===============
- RMAN-00571:===========================================================
- RMAN-03002:failureofrepaircommandat09/01/201323:15:16
- RMAN-06954:REPAIRcommandmustbeprecededbyADVISEcommandinsamesession
主要原因是:在运行repairfailure之前,要先运行advise failure,让rman列出错误,并且生成修复脚本,之后运行repair failure修复错误。
一、正确的恢复的过程如下:
1、启动RMAN客户机,并使用前一节介绍的数据库修复命令来解决丢失数据问题,我们从list failure命令开始:
- RMAN>listfailure;
- ListofDatabaseFailures
- =========================
- FailureIDPriorityStatusTimeDetectedSummary
- -----------------------------------------------
- 2002HIGHOPEN01-SEP-13Oneormorenon-systemdatafilesaremissing
2、advisefailure命令对记录在自动诊断信息库中的所有故障给出建议。默认时,此命令只列出具有critical或high优先级的那些故障。除了产生所有输入故障的摘要外,此命令还对每个故障提供一个建议修复选项。通常,advise failure命令同时给出自动和手动修复选项。在advisefailure命令输出结束时,RMAN生成一个脚本,列出建议的修复选项的细节。如果你想自己进行修复,可以直接使用这个脚本,或者对它进行修改。
- RMAN>advisefailure;
- ListofDatabaseFailures
- =========================
- FailureIDPriorityStatusTimeDetectedSummary
- -----------------------------------------------
- 2002HIGHOPEN01-SEP-13Oneormorenon-systemdatafilesaremissing
- analyzingautomaticrepairoptions;thismaytakesometime
- allocatedchannel:ORA_DISK_1
- channelORA_DISK_1:SID=10devicetype=DISK
- analyzingautomaticrepairoptionscomplete
- MandatoryManualActions
- ========================
- nomanualactionsavailable
- OptionalManualActions
- =======================
- 1.Iffile/u01/app/oracle/oradata/ocm/users01.dbfwasunintentionallyrenamedormoved,restoreit
- AutomatedRepairOptions
- ========================
- OptionRepairDescription
- ------------------------
- 1Restoreandrecoverdatafile4
- Strategy:Therepairincludescompletemediarecoverywithnodataloss
- Repairscript:/u01/app/oracle/diag/rdbms/ocm/ocm/hm/reco_3275375759.hm
3、利用advise failure命令提供的建议,epair failure根据建议修复错误。
- RMAN>repairfailure;
- Strategy:Therepairincludescompletemediarecoverywithnodataloss
- Repairscript:/u01/app/oracle/diag/rdbms/ocm/ocm/hm/reco_3275375759.hm
- contentsofrepairscript:
- #restoreandrecoverdatafile
- restoredatafile4;
- recoverdatafile4;
- sql'alterdatabasedatafile4online';
- Doyoureallywanttoexecutetheaboverepair(enterYESorNO)?Y
- executingrepairscript
- Startingrestoreat01-SEP-13
- usingchannelORA_DISK_1
- channelORA_DISK_1:startingdatafilebackupsetrestore
- channelORA_DISK_1:specifyingdatafile(s)torestorefrombackupset
- channelORA_DISK_1:restoringdatafile00004to/u01/app/oracle/oradata/ocm/users01.dbf
- channelORA_DISK_1:readingfrombackuppiece/u01/app/oracle/product/11.2.0/dbs/0uoiptgq_1_1
- channelORA_DISK_1:piecehandle=/u01/app/oracle/product/11.2.0/dbs/0uoiptgq_1_1tag=TAG20130901T230250
- channelORA_DISK_1:restoredbackuppiece1
- channelORA_DISK_1:restorecomplete,elapsedtime:00:00:03
- Finishedrestoreat01-SEP-13
- Startingrecoverat01-SEP-13
- usingchannelORA_DISK_1
- startingmediarecovery
- mediarecoverycomplete,elapsedtime:00:00:01
- Finishedrecoverat01-SEP-13
- sqlstatement:alterdatabasedatafile4online
- repairfailurecomplete
- Doyouwanttoopenthedatabase(enterYESorNO)?Y
- databaseopened