前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >机器断电导致Oracle数据库损坏的解决方法介绍

机器断电导致Oracle数据库损坏的解决方法介绍

原创
作者头像
北亚数据恢复中心
修改2020-05-28 17:31:24
1.7K0
修改2020-05-28 17:31:24
举报
文章被收录于专栏:数据恢复案例

服务器数据恢复故障

北京某公司的一台服务器,上层数据类型为Oracle数据库,由于服务器意外断电,导致数据库报错,报错内容为“system01.dbf需要更多的恢复来保持一致性”。由于客户的数据库并没有备份,仅有一些断断续续的归档日志,现在只能通过数据恢复手段来修复Oracle数据库。

数据恢复常规流程

1. 检测数据库故障情况;

2. 尝试挂起并修复数据库

3. 解析数据库文件

4. 导出并验证恢复的数据库文件

检测服务器及数据库情况

首先利用dbv命令检测数据文件是否是完整的。见下图所示:

通过上面的截图我们可以看到,我们检测的文件数据块中有40页的数据是检测失败的状态。另外有29页的索引数据也是失败状态。除此以外其他文件均为正常状态。

挂起并修复数据库

北亚数据恢复工程师在数据恢复专用服务器上搭建了一组Windows server 2008 x86环境,并安装了和客户原服务器上相同的数据库环境,尝试将数据库挂起来,查看数据库的报错情况,请见下图所示;

根据数据库的报错情况,北亚数据恢复工程师采取了借助在线日志恢复数据的方法,使用recover database命令。

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

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

通过上图截图内容可见,这类数据库内部错误是无法通过命令进行修复的,北亚数据恢复中心工程师借助expdp/exp工具尝试对数据库进行导出,但这两个工具导出数据库时依然有报错,数据库已经不可能进行修复。

解析数据库文件获取数据

使用北亚自主研发的一款dbf解析工具,获取到客户数据库内的数据。如下图所示:

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

导出数据库数据并验证

数据恢复工程师再次使用exp工具将数据库导出,导出命令:

exp system/abc  file=C:\test\dump\zxfg.dmp log=C:\test\dump\zxfg.log owner=zxfg

本次导出正常,没有任何报错。经客户验证,Oracle数据库完整,本次数据恢复圆满成功。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 服务器数据恢复故障
  • 数据恢复常规流程
  • 检测服务器及数据库情况
  • 挂起并修复数据库
  • 解析数据库文件获取数据
  • 导出数据库数据并验证
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档