ORACLE ADR 不能直接执行repair failure,需要先执行advice failure,生成修复脚本

本文介绍了Oracle数据库中丢失数据文件后的恢复流程。包括通过RMAN工具进行故障检测、分析及修复,具体步骤涉及listfailure、advisefailure与repairfailure等命令的使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >



正确答案:D

一、模拟上题的错误:

1、删除4号文件

[html] view plain copy
  1. [oracle@mydb~]$cd/u01/app/oracle/oradata/ocm/
  2. [oracle@mydbocm]$rm-rfusers01.dbf

2、数据库宕机

[html] view plain copy
  1. sys@OCM>shutdownabort;
  2. ORACLEinstanceshutdown.

3、启动数据库报错,与上题报错一样

[html] view plain copy
  1. sys@OCM>startup
  2. ORACLEinstancestarted.
  3. TotalSystemGlobalArea839282688bytes
  4. FixedSize2233000bytes
  5. VariableSize583011672bytes
  6. DatabaseBuffers247463936bytes
  7. RedoBuffers6574080bytes
  8. Databasemounted.
  9. ORA-01157:cannotidentify/lockdatafile4-seeDBWRtracefile
  10. ORA-01110:datafile4:'/u01/app/oracle/oradata/ocm/users01.dbf'

4、如果试图在没有执行advise failure命令时使用repair failure命令,将出现如下错误:

[html] view plain copy
  1. [oracle@mydb~]$rmantarget/
  2. RMAN>repairfailure;
  3. usingtargetdatabasecontrolfileinsteadofrecoverycatalog
  4. RMAN-00571:===========================================================
  5. RMAN-00569:===============ERRORMESSAGESTACKFOLLOWS===============
  6. RMAN-00571:===========================================================
  7. RMAN-03002:failureofrepaircommandat09/01/201323:15:16
  8. RMAN-06954:REPAIRcommandmustbeprecededbyADVISEcommandinsamesession

   主要原因是:在运行repairfailure之前,要先运行advise failure,让rman列出错误,并且生成修复脚本,之后运行repair failure修复错误。

一、正确的恢复的过程如下:

1、启动RMAN客户机,并使用前一节介绍的数据库修复命令来解决丢失数据问题,我们从list failure命令开始:

[html] view plain copy
  1. RMAN>listfailure;
  2. ListofDatabaseFailures
  3. =========================
  4. FailureIDPriorityStatusTimeDetectedSummary
  5. -----------------------------------------------
  6. 2002HIGHOPEN01-SEP-13Oneormorenon-systemdatafilesaremissing


2、advisefailure命令对记录在自动诊断信息库中的所有故障给出建议。默认时,此命令只列出具有critical或high优先级的那些故障。除了产生所有输入故障的摘要外,此命令还对每个故障提供一个建议修复选项。通常,advise failure命令同时给出自动和手动修复选项。在advisefailure命令输出结束时,RMAN生成一个脚本,列出建议的修复选项的细节。如果你想自己进行修复,可以直接使用这个脚本,或者对它进行修改。

  

[html] view plain copy
  1. RMAN>advisefailure;
  2. ListofDatabaseFailures
  3. =========================
  4. FailureIDPriorityStatusTimeDetectedSummary
  5. -----------------------------------------------
  6. 2002HIGHOPEN01-SEP-13Oneormorenon-systemdatafilesaremissing
  7. analyzingautomaticrepairoptions;thismaytakesometime
  8. allocatedchannel:ORA_DISK_1
  9. channelORA_DISK_1:SID=10devicetype=DISK
  10. analyzingautomaticrepairoptionscomplete
  11. MandatoryManualActions
  12. ========================
  13. nomanualactionsavailable
  14. OptionalManualActions
  15. =======================
  16. 1.Iffile/u01/app/oracle/oradata/ocm/users01.dbfwasunintentionallyrenamedormoved,restoreit
  17. AutomatedRepairOptions
  18. ========================
  19. OptionRepairDescription
  20. ------------------------
  21. 1Restoreandrecoverdatafile4
  22. Strategy:Therepairincludescompletemediarecoverywithnodataloss
  23. Repairscript:/u01/app/oracle/diag/rdbms/ocm/ocm/hm/reco_3275375759.hm

3、利用advise failure命令提供的建议,epair failure根据建议修复错误。

[html] view plain copy
  1. RMAN>repairfailure;
  2. Strategy:Therepairincludescompletemediarecoverywithnodataloss
  3. Repairscript:/u01/app/oracle/diag/rdbms/ocm/ocm/hm/reco_3275375759.hm
  4. contentsofrepairscript:
  5. #restoreandrecoverdatafile
  6. restoredatafile4;
  7. recoverdatafile4;
  8. sql'alterdatabasedatafile4online';
  9. Doyoureallywanttoexecutetheaboverepair(enterYESorNO)?Y
  10. executingrepairscript
  11. Startingrestoreat01-SEP-13
  12. usingchannelORA_DISK_1
  13. channelORA_DISK_1:startingdatafilebackupsetrestore
  14. channelORA_DISK_1:specifyingdatafile(s)torestorefrombackupset
  15. channelORA_DISK_1:restoringdatafile00004to/u01/app/oracle/oradata/ocm/users01.dbf
  16. channelORA_DISK_1:readingfrombackuppiece/u01/app/oracle/product/11.2.0/dbs/0uoiptgq_1_1
  17. channelORA_DISK_1:piecehandle=/u01/app/oracle/product/11.2.0/dbs/0uoiptgq_1_1tag=TAG20130901T230250
  18. channelORA_DISK_1:restoredbackuppiece1
  19. channelORA_DISK_1:restorecomplete,elapsedtime:00:00:03
  20. Finishedrestoreat01-SEP-13
  21. Startingrecoverat01-SEP-13
  22. usingchannelORA_DISK_1
  23. startingmediarecovery
  24. mediarecoverycomplete,elapsedtime:00:00:01
  25. Finishedrecoverat01-SEP-13
  26. sqlstatement:alterdatabasedatafile4online
  27. repairfailurecomplete
  28. Doyouwanttoopenthedatabase(enterYESorNO)?Y
  29. databaseopened
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值