数据库数据恢复—服务器异常断电导致Oracle数据库故障的数据恢复案例

电子说

1.4w人已加入

描述

Oracle数据库故障:
某公司一台服务器上部署Oracle数据库。服务器意外断电导致数据库报错,报错内容为“system01.dbf需要更多的恢复来保持一致性”。该Oracle数据库没有备份,仅有一些断断续续的归档日志。

Oracle数据库恢复流程:
1、检测数据库故障情况;
2、尝试挂起并修复数据库;
3、解析数据库文件;
4、导出并验证恢复的数据库文件。

Oracle数据库数据恢复过程:
1、检测服务器及数据库情况。利用dbv命令检测数据文件是否是完整的。

数据库北亚企安数据恢复—Oracle数据库数据恢复



检测后发现文件数据块中有40页的数据是检测失败的状态,另外有29页的索引数据也是失败状态。除此以外其他文件均为正常状态。
2、挂起并修复数据库
北/企安数据恢复工程师在数据恢复服务器上搭建了一组Windows server x86环境,安装了和原服务器上相同的数据库环境。尝试将数据库挂起来,查看数据库的报错情况。

数据库北亚企安数据恢复—Oracle数据库数据恢复



3、根据数据库的报错情况,数据恢复工程师试图借助在线日志恢复数据,使用recover database命令。

数据库北亚企安数据恢复—Oracle数据库数据恢复 数据库北亚企安数据恢复—Oracle数据库数据恢复



4、经过修复发现,由于归档日志不连续,恢复数据库所需时间段的归档日志缺失,只能使用cancel参数进行不完全数据恢复。

数据库北亚企安数据恢复—Oracle数据库数据恢复



5、数据恢复工程师再次执行恢复命令,打开数据库,查询实例状态有无报错。经过查询,仍有部分数据报错,报错内容为“ora_00600”。

数据库北亚企安数据恢复—Oracle数据库数据恢复 数据库北亚企安数据恢复—Oracle数据库数据恢复



这类数据库内部错误是无法通过命令进行修复的。数据恢复工程师借助expdp/exp工具尝试对导出数据库,但这两个工具导出数据库时依然有报错,数据库已经不可能进行修复。
6、解析数据库文件获取数据。
使用北亚企安自主研发的dbf解析工具,获取到数据库内的数据。

数据库北亚企安数据恢复—Oracle数据库数据恢复



7、获取到数据库数据后在数据恢复专用服务器内搭建数据库环境,创建数据库、用户、分配表空间等。将解析出来的数据库数据迁移到新数据库中。使用toad for oracle工具验证数据。

数据库北亚企安数据恢复—Oracle数据库数据恢复



8、导出数据库数据并验证。
数据恢复工程师再次使用exp工具将数据库导出。这次导出正常,没有任何报错。经用户方验证,Oracle数据库数据完整,本次数据恢复工作完成。

数据库北亚企安数据恢复—Oracle数据库数据恢复


审核编辑 黄宇
 

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分