【数据库数据恢复】windows server环境下SqlServer数据库文件未知原因丢失的数据恢复案例
  TEZNKK3IfmPf 2023年11月13日 57 0

数据库数据恢复环境:

5块2T硬盘组成的RAID5,划分LUN供windows服务器使用;

windows服务器内装有Sql Server数据库;

存储空间内共有三个逻辑分区大小分别为:500G、800G、2.3T。

 

数据库故障:

未知原因的数据库文件丢失,涉及到5个数据库约6000张表,不能确定数据存储位置。数据库文件丢失后服务器仍处于开机状态,但并未写入大量数据。管理员联系北亚数据恢复中心进行数据恢复。

 

数据库故障检测:

1、数据恢复工程师利用分析提取出来的RAID信息及内部数据块信息重组RAID。

 

【数据库数据恢复】windows server环境下SqlServer数据库文件未知原因丢失的数据恢复案例

重组RAID

2、提取LUN内三个分区镜像。

3、扫描文件系统内丢失文件,未找到被删除的数据库文件,数据库文件丢失,无法通过文件系统层面恢复数据。

 

 

数据库数据恢复过程:

1、经过检测后判定数据库文件丢失且无法恢复,数据恢复工程师只能通过扫描数据页,提取页内记录的方式进行数据恢复。

2、使用北亚数据恢复中心自主研发的数据页扫描程序扫描分区内数据页并提取。扫描两个分区镜像后发现系统盘分区内数据页数量极少且数据页断裂情况严重,另一分区内扫描到数据页数量较多,暂定此分区为数据库文件存储空间。

 

【数据库数据恢复】windows server环境下SqlServer数据库文件未知原因丢失的数据恢复案例

扫描数据页

 

3、重组系统表。Sql Server数据库使用系统表来管理所有用户表,系统表记录了各表的列数、数据类型及约束信息等。解析系统表过程中发现提取出的数据页内系统表损坏,无法正常读取信息。数据恢复工程师与管理员沟通后,得知有备份文件且备份完成后没有大量改动表结构,系统表可用。

4、还原备份。

 

【数据库数据恢复】windows server环境下SqlServer数据库文件未知原因丢失的数据恢复案例

还原备份

 

5、分别提取库中各表表结构信息。

 

【数据库数据恢复】windows server环境下SqlServer数据库文件未知原因丢失的数据恢复案例

提取表结构信息

 

6、解析表结构脚本。将各表的列信息存入数据库内便于后续使用。

 

【数据库数据恢复】windows server环境下SqlServer数据库文件未知原因丢失的数据恢复案例

扫描脚本文件

 

【数据库数据恢复】windows server环境下SqlServer数据库文件未知原因丢失的数据恢复案例

表结构信息存入数据库

 

7、解析系统表获取用户表id信息、关联表结构与数据页。(为保护隐私,后续步骤涉及用户表表名及数据页内数据部分均未截图)

8、新建数据库,使用北亚自主编写的软件解析记录并导入到数据恢复环境内。

9、整理恢复结果。在此分区内除数据库文件外还存有若干备份文件,导出记录后可能存在重复数据,必须去重。数据恢复工程师编写SQL存储过程进行去重。

 

【数据库数据恢复】windows server环境下SqlServer数据库文件未知原因丢失的数据恢复案例

数据库去重

 

10、验证数据。管理员在查验过数据后表示数据没有问题,移交数据到管理员准备好的存储设备,本次数据恢复成功。

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月13日 0

暂无评论

推荐阅读
  TEZNKK3IfmPf   2024年04月26日   56   0   0 java数据库sql
  TEZNKK3IfmPf   2024年05月31日   26   0   0 sqlite数据库
  TEZNKK3IfmPf   2024年05月31日   31   0   0 数据库mysql
  TEZNKK3IfmPf   2024年05月31日   27   0   0 数据库mysql
TEZNKK3IfmPf