Mysql如何通过ibd文件恢复数据
作者:Smile_微笑
Mysql ibd文件恢复问题
恢复步骤
1、创建数据库(随意创建)
2、创建数据表(备注:表结构要和要恢复的表结构一致,row_format要和ibd文件的row_format一致,否则,会提示两者不一致。 当前row_format=dynamic)
3、表的属性查看
我们使用:show table status like ‘matlab’\G,查看表的属性
备注:创建表时候的row_format和表属性的不一致,基于innodb是,要把row_format设置成dynamic时,需要修改mysql的全局配置,直接在myql命令中修改:set global innodb_file_format=Barracuda;
4、表错误信息查看 show warnings
5、说明我们在恢复表的时候,要保证row_format和ibd文件的一致,如果ibd文件是compact的话,需要建表的时候,设置成row_format=compact,在恢复的时候,自行解决,从第6步开始,重点说明如何去恢复。
6、恢复第一步:移除表空间
**alter table matlab DISCARD TABLESPACE;**
7、恢复第二步:将备份的ibd文件,放到mysql->data->创建的数据库名称->,将ibd拷贝到此目录下,如下所示具体路径查看
-- 使用sql查询数据目录 **show global variables like '%datadir%';**
8、恢复第三步:重新导入表空间
**alter table matlab IMPORT TABLESPACE;**
9、当执行到上一步完成后,我们发现数据库中的数据已经完全恢复过来了
10、数据表的结构一定要和恢复前的数据表结构一致,否则恢复失败,导致mysql进程重启,详细情况需要查看mysql的error日志进行分析,另外,mysql的CE工具提供了便捷的mysql参数配置修改功能
mysql基于idb文件恢复数据问题
适用于mysql8.0+,mysql5版本没测试过
数据库因为磁盘损坏起不来了,好在data目录下的idb文件还在,可以基于idb文件恢复数据
步骤:
- 创建schem和表
- 将新建表关联
- 复制idb文件
- import表
注意执行顺序
创建shcema
需要找一个同版本的mysql数据库,创建一个空的schema
create database test;
然后创建一个相同结构的表结构
//测试环境数据库损坏,我登录开发环境切换到对应db下,查看对应的表结构 //如果有备份的库也可以,导入一个schmea查看表结构。或者从开发人员那里索要表结构 show create table dev; //这里是我在开发环境上看到的表结构 CREATE TABLE `match_rules` ( `id` bigint NOT NULL AUTO_INCREMENT, `app_id` varchar(32) DEFAULT NULL, `rule_id` varchar(32) DEFAULT NULL, `rule_type` int DEFAULT NULL, `conditions` json DEFAULT NULL, `results` json DEFAULT NULL, `show_data` json DEFAULT NULL, `create_time` datetime DEFAULT NULL, `update_time` datetime DEFAULT NULL, `valid` int DEFAULT NULL, `version_number` int DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=149 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci; //粘贴上面的表结构,到新建的库下执行,注意切换到对应的schema上
将新建表关联
上面我们把表结构创建好了,接下来需要将表关联
ALTER TABLE your_table DISCARD TABLESPACE;
复制idb文件
首先,将 .ibd 文件复制到 MySQL 数据目录中,例如 /var/lib/mysql/your_database/ 目录。
请确保文件具有正确的权限,并且 MySQL 用户可以访问该文件
import表
//执行完后我们可以切换到对应的表下面,可以看到数据了 ALTER TABLE your_table IMPORT TABLESPACE;
//如果是给开发人员使用,记得授权
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。