数据库

位置:IT落伍者 >> 数据库 >> 浏览文章

Oracle重做日志丢失的故障处理


发布日期:2021年06月22日
 
Oracle重做日志丢失的故障处理

Oracle重做日志

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

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

如果数据库在启动时检测到重做日志丢失数据库将无法启动如果数据库在运行时切换日志文件组检测到下一组或者全部的重做日志丢失数据库将会崩溃由于磁盘介质损坏或者人为的误删除文件造成严重后果的事件近期时有发生本文列举了重做日志丢失的数据库恢复但如果按照冗余原则合理分布日志文件组的成员如果工程师了解日志文件的基本原理和使用原则就完全可以避免出现下列问题

恢复方法

故障现象

SQL> startup mount

Oracle Instance Started

Database mounted

ORA: open failed for members of log group of thread

ORA: online log thread : /ORACLE/ORADATA/H/REDOLOG

ORA: unable to open file

OSD: unable to open file

O/SError: (OS ) The system cannot find the file specified

恢复注意事项

以下所列举的恢复方法都属于不完全恢复或者强制恢复会丢失当前重做日志中的事务数据一旦操作不当将带来数据丢失等严重后果请遵循以下几个恢复原则

请勿在生产系统上试用

如果生产系统出现重做日志文件丢失的故障请勿自行操作破坏现场应该立刻联系Oracle工程师

恢复成功之后需要马上做一次数据库的全备份

建议重做日志文件一定要实现镜象在不同的磁盘上避免这种情况的发生

恢复方法

首先检查重做日志文件状态看看报错的日志文件的状态是否为Current

SQL> select * from v$log;

SQL> select * from v$logfile;

如果重做日志文件状态为Inactive我们可以直接清除该日志文件的内容

SQL> alter database clear logfile /ORACLE/ORADATA/H/REDOLOG;

如果重做日志文件状态为Current恢复工作较为复杂有以下四种情况

)通过下面步骤数据库顺利打开

SQL> recover database until cancel;

Type Cancel when prompted

SQL>alter database open resetlogs;

)第一种情况的recover database until cancel 操作遇到ORAORAORA错误需要整个数据库的物理备份并根据归档日志恢复到错误时间点前提是数据库是归档模式

restore old backup

SQL> startup mount

SQL> recover database until cancel using backup controlfile;

SQL> alter database open resetlogs;

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

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

? 关闭数据库

SQL>shutdown immediate

? 在init<sid>ora中加入如下参数

_allow_resetlogs_corruption=TRUE

? 重新启动数据库利用until cancel恢复

SQL>recover database until cancel;

Cancel

? 打开数据库

SQL>alter database open resetlogs;

? 数据库被打开后马上执行一个全库导出

关闭数据库在init<sid>ora中去掉_all_resetlogs_corrupt参数

if ($ != jQuery) { $ = jQuerynoConflict(); }

上一篇:数据库的查询优化方法分析

下一篇:Oracle的操作系统身份认证