环境

操作系统:CentOS 7 Mysql版本:8.0.x

问题

如果Mysql服务无法启动,则可以通过Mysql表对应的.ibd文件恢复数据,如果你的Mysql服务可以正常启动,就不要使用这种方式了

办法

  1. 创建一张表,表结构与原表结构一致
  2. 删除新建的表空间
ALTER TABLE <table_name> DISCARD TABLESPACE;
  1. 将待恢复的.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方式部署,需要将.ibd文件拷贝到,映射到Mysql的Docker容器路径下,修改权限需要进入到Mysql所在的Docker容器!重点,不是直接在安装Docker那台机器上修改权限,一定要进入到myslq所在的docker容器 docker进入某容器命令,假如我的容器名是docker_mysql

docker exec -it docker_mysql /bin/bash
  1. 导入表空间
ALTER TABLE <table_name> IMPORT TABLESPACE;