前情
在windows环境下修改了MySQL的my.cnf文件造成数据无法启动。
- 只复制了data下的对应数据库的文件夹
- 使用MySQL Installer卸载并删除对应的data文件夹
- 使用MySQL Installer安装
- 将数据库文件夹复制到data目录下(原以为重启数据库后会自动识别)
- 数据库无法识别
网上的教程都是针对复制了整个data文件的说明,假设使用docker将数据卷的内容备份了,迁移时重新指定数据卷就可以自动识别了,这个是正常的套路
车祸现场恢复过程
近600万的数据无法恢复,单个库的大小接近2G。
恢复模型
从开发环境或测试环境中将数据模型导出
模型恢复
在新建的环境中创建与删除前一模一样的数据库名称,使用导出数据模型恢复数据库结构
数据恢复
- 将原复制的数据库文件夹覆盖新实例创建的文件夹
- 重启数据库实例
- 原覆盖的目标表已无法查询,报异常如下:
Error Code:1812. Tablespace is missing for table <table_name>
- 使用下面语句可解决:
ALTER TABLE <table_name> IMPORT TABLESPACE;
- 索引丢失问题(开发环境没有索引),在恢复的大表中新建索引失败,几百万的数据如果没有索引一查询就是全表,多查几次就把实例的CPU搞趴了,特别是又有count的情况。
- 新建临时表,该临时表结构与原表一模一样,创建好索引
- 执行复制语句:
insert into A select * from B;
8.到此数据已恢复,增删改查正常
总共折腾了4个小时,数据还原过程还经历了磁盘空间不足的情况,切记对数据库操作时能备份数据一定、一定、一定要备份数据。