1818IP-服务器技术教程,云服务器评测推荐,服务器系统排错处理,环境搭建,攻击防护等

当前位置:首页 - 数据库 - 正文

君子好学,自强不息!

如果数据库在启动时检测到重做日志丢失,数据库将无法启动。如果数据库在运行时切换日志文件组,检测到下一组或者全部的重做日志丢失,数据库将会崩溃。所以有必要学习下Oracle重做日志恢复的技巧。

由于磁盘介质损坏或者人为的误删除文件,造成严重后果的事件近期时有发生。本文列举了重做日志丢失的数据库恢复,但如果按照冗余原则合理分布日志文件组的成员,如果工程师了解日志文件的基本原理和使用原则,就完全可以避免出现下列问题。

Oracle重做日志文件循环记录了数据库所有的事务。它的大小、个数和存储位置对数据库性能和恢复有重要影响。它一般由大小相同的几组文件构成。我们可以查看数据库视图v$logfile知道redo logfile的个数和存储位置。对每一个Oracle数据库都要求至少具有两个联机重做日志。

每一次新的事务提交时,Oracle将该事务写入日志文件,但并非此时也将修改的数据块写回原数据文件。由于内存读写和磁盘I/O存在几个数量级的效率差别,Oracle通过减少数据文件的物理I/O读写来大大提高数据库的性能;同时,又通过优先写日志文件来保证数据的正确性和一致性。基于这种机制,Oracle重做日志文件在数据库的实例恢复和介质恢复时至关重要,是oracle数据库最重要的物理文件之一。

恢复方法

故障现象

SQL>startupmount 
  • OracleInstanceStarted Databasemounted
  • ORA-00313:openfailedformembersofloggroup1ofthread1 ORA-00312:onlinelog1thread1:'/ORACLE/ORADATA/H817/REDO01.LOG'
  • ORA-27041:unabletoopenfile OSD-04002:unabletoopenfile
  • O/S-Error:(OS2)Thesystemcannotfindthefilespecified.
  • Oracle重做日志恢复注意事项

    以下所列举的恢复方法,都属于不完全恢复或者强制恢复,会丢失当前重做日志中的事务数据。一旦操作不当,将带来数据丢失等严重后果,请遵循以下几个恢复原则: 1.请勿在生产系统上试用。 2.如果生产系统出现重做日志文件丢失的故障,请勿自行操作破坏现场,应该立刻联系Oracle工程师。 3.恢复成功之后,需要马上做一次数据库的全备份。 4.建议重做日志文件一定要实现镜象在不同的磁盘上,避免这种情况的发生。

    恢复方法 1. 首先检查重做日志文件状态,看看报错的日志文件的状态是否为Current

    SQL>select*fromv$log; 
  • SQL>select*fromv$logfile;
  • 2. 如果重做日志文件状态为Inactive,我们可以直接清除该日志文件的内容:

    SQL>alterdatabaseclearlogfile'/ORACLE/ORADATA/H817/REDO01.LOG';
    3.如果重做日志文件状态为Current,恢复工作较为复杂,有以下四种情况:
    1)通过下面步骤,数据库顺利打开
    
    SQL>recoverdatabaseuntilcancel; 
  • TypeCancelwhenprompted SQL>alterdatabaseopenresetlogs;
  • 2)***种情况的’recover database until cancel’ 操作遇到ORA-01547,ORA-01194,ORA-01110错误,需要整个数据库的物理备份,并根据归档日志恢复到错误时间点,前提是数据库是归档模式。#p#

    restoreoldbackup 
  • SQL>startupmount SQL>recoverdatabaseuntilcancelusingbackupcontrolfile;
  • SQL>alterdatabaseopenresetlogs;
  • 3)如果数据库是非归档模式,只能恢复整个物理备份,然后直接打开数据库。这种情况将丢失物理备份至故障发生前的全部数据。

    4)如果数据库是非归档模式,且没有物理备份,只能通过特殊的隐含参数,允许数据库不一致的状况下打开数据库。这种恢复方法是没有办法之后的恢复方法,将导致数据库不一致,一般情况下不要采用。如确有需要,请在Oracle的技术人员指导下使用该方法。

    关闭数据库 
  • SQL>shutdownimmediate 在init<sid>.ora中加入如下参数
  • _allow_resetlogs_corruption=TRUE 重新启动数据库,利用untilcancel恢复
  • SQL>recoverdatabaseuntilcancel; Cancel
  • 打开数据库 SQL>alterdatabaseopenresetlogs;
  • 数据库被打开后,马上执行一个全库导出。 关闭数据库,在init.ora中去掉_all_resetlogs_corrupt参数

    本文来源:1818IP

    本文地址:https://www.1818ip.com/post/11488.html

    免责声明:本文由用户上传,如有侵权请联系删除!

    发表评论

    必填

    选填

    选填

    ◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。