服务器数据恢复—云服务器mysql数据库表被truncate的数据恢复案例

云服务器数据恢复环境:

阿里云ECS网站服务器,linux操作系统+mysql数据库。

云服务器故障:

在执行数据库版本更新测试时,在生产库误执行了本来应该在测试库执行的sql脚本,导致生产库部分表被truncate,还有部分表内的少量数据被delete。该实例内数据表均采用innodb作为默认存储引擎。

云服务器数据恢复过程:

1、由于用户ECS内还有其他业务在运行,为避免被truncate表的底层数据被破坏,首先将mysql数据库的data目录所在分区备份。

2、需要恢复的十多个表内不存在大字段类型值和myisam引擎表,直接扫描数据段并下载恢复所必需的数据库段碎片。由于innodb引擎表恢复数据须依赖表结构信息,mysql的表结构信息存储于对应表名的.frm文件内。经过检测发现.frm文件完好,可直接使用。下载需要恢复的表所对应的.frm文件。

3、读取&分析数据段内系统表信息,获取需要恢复的十多个表在系统表内的注册信息。

4、在下载完成的数据段文件内提取对应于各表的数据页,解析对应表的.frm文件获取该表的表结构信息。通过表结构信息获取到底层数据分配规则,北亚企安数据恢复工程师按照规则拆分数据段内二进制数据并将不同类型数据进行字符展示转换(各类整型、浮点型、时间型等),完成数据段到sql语句的转换。

5、恢复被delete数据的表的流程类似恢复被truncate表的流程,差异在于解析数据时需要提取被标注为"delete"的记录。

6、根据解析出的表结构信息在恢复环境中的mysql实例内创建表,将恢复出的数据导入。

7、由于直接从底层抓取出的记录可能存在主键不唯一(引擎在存储时产生的临时记录)、记录重复(缓冲段)和乱码(扫描数据段时出现特征值匹配成功但不属于该表的数据段)等情况,北亚企安数据恢复工程师人工处理提取记录存在的异常。

8、由用户方远程桌面的方式验证恢复数据的正确性和完整性。经过用户方工程师的多方验证,确认被truncate的表和被delete记录的表的数据恢复完整,数据正确有效。本次数据恢复工作完成。

相关推荐
北亚数据恢复4 小时前
服务器数据恢复—Raid5多盘掉线,存储如何“起死回生”?
数据恢复·服务器数据恢复·北亚数据恢复·raid5数据恢复·硬盘数据恢复
北亚数据恢复1 天前
服务器数据恢复—Raid5双硬盘坏,热备盘“罢工”咋恢复?
数据恢复·服务器数据恢复·北亚数据恢复·raid5数据恢复·硬盘数据恢复
奥尔特星云大使6 天前
mysql 全备+binlog恢复数据
数据库·mysql·adb·数据恢复·全量备份·binlog日志·二进制日志
(天津)鸿萌数据安全11 天前
微软 2025 年 8 月更新:对固态硬盘与电脑功能有哪些潜在的影响
数据恢复·数据备份·微软漏洞
科技智驱11 天前
电脑格式化了还能恢复数据吗?硬盘格式化恢复教程分享
电脑·数据恢复
程序设计实验室13 天前
硬盘突然坏掉,我花了半个月才把数据救回来…(附数据恢复工具)
数据恢复·个人数据保全计划
龙信科技1 个月前
【国内电子数据取证厂商龙信科技】被格式化的手机如何恢复数据
科技·智能手机·数据恢复
北亚数据恢复1 个月前
服务器数据恢复—Raid6阵列崩溃导致上层分区无法访问的数据恢复案例
数据恢复·服务器数据恢复·北亚数据恢复·raid6数据恢复
北亚数据恢复1 个月前
服务器数据恢复—热备盘上线失败如何恢复数据?
数据恢复·服务器数据恢复·北亚数据恢复
科技智驱2 个月前
两款免费数据恢复软件介绍,Win/Mac均可用
电脑·数据恢复