Mysql通过ibd文件恢复数据
环境
操作系统: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> |
注意:如果mysql服务是通过Docker方式部署,需要将.ibd文件拷贝到,映射到Mysql的Docker容器路径下,修改权限需要进入到Mysql所在的Docker容器!重点,不是直接在安装Docker那台机器上修改权限,一定要进入到myslq所在的docker容器 docker进入某容器命令,假如我的容器名是docker_mysql
docker exec -it docker_mysql /bin/bash |
- 导入表空间
ALTER TABLE <table_name> IMPORT TABLESPACE; |
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 IT者!