某单位5个数据库丢失的数据恢复过程

故障描述:5块2T硬盘组建RAID5,划分LUN供windows服务器使用。在windows服务器内装有SqlServer2008数据库。存储空间内共有三个逻辑分区,大小分别为500G、800G、2.3T。数据库文件丢失,主要涉及五个数据库,表个数约为6000个左右。丢失原因未知,且不能确定数据存储位置。三个数据库的大小分别为8G、15G、20G。

2、提取LUN内三个分区镜像。3、扫描文件系统内丢失文件,未找到被删除数据库文件。4、初检结果为数据库文件丢失,通过文件系统角度无法恢复。恢复流程:1、制定恢复方案。在数据库文件被删除且判定为无法恢复文件后,只能通过扫描数据页,并提取页内记录的方式进行恢复。2、使用北亚自主编数据页扫描程序扫描分区内数据页并提取。

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

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

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

7、解析系统表获取用户表id信息、关联表结构与数据页。(为保护客户隐私,后续步骤涉及用户表表名及数据页内数据部分均未截图)8、新建数据库,使用北亚自主编写软件解析记录并导入到恢复环境内。9、整理恢复结果。在此分区内除数据库文件外还存有备份文件若干,所以在导出记录后可能存在重复数据,必须去重。编写SQL存储过程进行去重。

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20181019A0I86900?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 yunjia_community@tencent.com 删除。

扫码关注云+社区

领取腾讯云代金券