环境
操作系统:CentOS 7
Mysql版本:8.0.x
问题
如果Mysql服务无法启动,则可以通过Mysql表对应的.ibd文件恢复数据,如果你的Mysql服务可以正常启动,就不要使用这种方式了
办法
- 创建一张表,表结构与原表结构一致
- 删除新建的表空间
ALTER TABLE <table_name> DISCARD TABLESPACE;
- 将待恢复的
.ibd文件copy到目标数据库文件夹下,并修改文件权限:
cp <table_name>.ibd /var/lib/mysql/<database_name>
cd /var/lib/mysql/<database_name>
chown mysql:mysql <table_name>.ibd
注意:如果mysql服务是通过Docker方式部署,需要将
docker进入某容器命令,假如我的容器名是docker_mysql
docker exec -it docker_mysql /bin/bash
- 导入表空间
ALTER TABLE <table_name> IMPORT TABLESPACE;