【数据库数据恢复】断电导致Oracle数据库启动报错,数据丢失的数据恢复案例

数据库故障情况:

由于机房异常断电,Oracle数据库重新启动后报错:“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。Oracle数据库没有备份,归档日志不连续。管理员联系到我们数据恢复中心寻求帮助。管理员提供了故障数据库的在线文件,需要恢复zxfg用户下的数据。

数据库数据恢复方案:

检测数据库故障,尝试挂起并修复数据库,解析数据文件。

数据库数据恢复过程:

1、检测数据文件的完整性。

【数据库数据恢复】断电导致Oracle数据库启动报错,数据丢失的数据恢复案例

结果发现SYSAUX01.DBF文件数据块(Data)检测失败40页,索引页(Index)检测失败29页,可以初步判断SYSAUX01.DBF存在坏块。通过dbv对数据文件的完整性进行检验,确认了SYSAUX01.DBF存在坏块,其他文件经过检测都是完整的。

2、利用管理员提供的数据库在线文件在本地挂起数据库,修复故障数据库并导出数据。

a、创建新的windows server系统,安装和用户原始环境数据库版本一致的oracle数据库,挂起数据库。

【数据库数据恢复】断电导致Oracle数据库启动报错,数据丢失的数据恢复案例

b、启动数据库报ORA-01110错误,System01.dbf需要更多一致性恢复。使用recover database命令,利用在线日志做介质恢复。

【数据库数据恢复】断电导致Oracle数据库启动报错,数据丢失的数据恢复案例

c、故障数据库的控制文件已被修改,需要使用控制文件恢复数据库。

【数据库数据恢复】断电导致Oracle数据库启动报错,数据丢失的数据恢复案例

d、恢复数据库需要的归档日志已经丢失,只能使用cancel参数进行不完全恢复。

【数据库数据恢复】断电导致Oracle数据库启动报错,数据丢失的数据恢复案例

e、再次执行alter database open命令,打开数据库。

【数据库数据恢复】断电导致Oracle数据库启动报错,数据丢失的数据恢复案例

f、查询实例状态,数据库报ora_00600错误;进行其他查询发现一些查询可以进行,一些查询报错,报错都是ora_00600错误。

【数据库数据恢复】断电导致Oracle数据库启动报错,数据丢失的数据恢复案例

g、查看警告日志,追踪文件,查看内部错误代码;

警告日志部分内容如下:ORA-00600: internal error code, arguments: [13013], [5001], [267], [8456009], [5], [8456009], [17], [], [], [], [], []

Non-fatal internal error happenned while SMON was doing logging scn->time mapping.

h、用expdp/exp工具导出数据库。expdp导出数据库报错,和上面查询报同样的错误。sysaux01.dbf文件损坏导致expdp工具不可用,导出数据库失败。

【数据库数据恢复】断电导致Oracle数据库启动报错,数据丢失的数据恢复案例

尝试使用exp导出数据库但是报同样的错误。数据库报严重内部错误,导出工具exp无法使用,甚至一些查询都不能进行,导出数据库失败。

i、通过上面的尝试,基本可以确定故障数据库的恢复已经不可能。数据库数据恢复工程师使用北亚自主研发DBF解析工具获取数据。

【数据库数据恢复】断电导致Oracle数据库启动报错,数据丢失的数据恢复案例

j、迁移对象到数据库中。创建数据库,在数据库中创建用户,为用户分配表空间,解锁用户并授权。然后通过数据搭桥的方式,将解析到的用户对象迁移到数据库中。

k、使用toad for oracle工具验证数据。

【数据库数据恢复】断电导致Oracle数据库启动报错,数据丢失的数据恢复案例

l、使用exp或者expdp导出zxfg用户下的所有对象。本案例是采用exp导出数据:

命令如下:exp system/abc  file=C:testdumpzxfg.dmp log=C:testdumpzxfg.log owner=zxfg

【数据库数据恢复】断电导致Oracle数据库启动报错,数据丢失的数据恢复案例

发表评论

相关文章