
Temps/usr/local/mysql/var/XXXXXX下存放着mysql所有数据文件?
那把这个目录下的所有文件直接拷贝到mysql(usr/local/mysql/var/XXXXXX,然后修改mycnf文件
在[mysqld]元素下重新指定datadir和basedir参数,前者是mysql数据文件目录,后者是mysql安装根目录;
如果存在innodb引擎表,那么还要重新制定innodb_data_home_dir和innodb_data_file_path
前者是ibdata文件的目录,后者需要指定ibdata文件的大小,以及自增颗粒度,注意,你迁移的数据文件中本身就存在ibdata文件,所以innodb_data_file_path设置的大小必须和他一致,不然启动不了。
涉及到迁移,做好备份,以防误 *** 作导致数据丢失。
ibdata1
------------------------------------------------
这个只是innodb的数据文件,还有表定义那部分呢
除了innodb存储引擎外,你是否还有别的存储引擎在用的呢
以前备的时候是直接档下来的,没有转换成SQL格式
------------------------------------------------
你拷贝文件全了吗如果拷贝全了的话(要拷贝mysql数据文件目录下的data整个目录,还有innodb下的innodb_data_home_dir、innodb_log_group_home_dir等目录下的文件,一定要拷贝全,切记!!!),那直接复制过去覆盖就可以用了的(即冷备份)
否则,你只有ibdata1文件,而没有其他关联的文件(如表定义的frm后缀文件),则就比较难恢复了,除非你先全部把所有表都重新定义一遍,然后再拷贝ibdata1覆盖了。
MySQL 在崩溃恢复时,会遍历打开所有 ibd 文件的 header page 验证数据字典的准确性,如果 MySQL 中包含了大量表,这个校验过程就会比较耗时。 MySQL 下崩溃恢复确实和表数量有关,表总数越大,崩溃恢复时间越长。另外磁盘 IOPS 也会影响崩溃恢复时间,像这里开发库的 HDD IOPS 较低,因此面对大量的表空间,校验速度就非常缓慢。另外一个发现,MySQL 8 下正常启用时居然也会进行表空间校验,而故障恢复时则会额外再进行一次表空间校验,等于校验了 2 遍。不过 MySQL 80 里多了一个特性,即表数量超过 5W 时,会启用多线程扫描,加快表空间校验过程。
如何跳过校验MySQL 57 下有方法可以跳过崩溃恢复时的表空间校验过程嘛?查阅了资料,方法主要有两种:
1 配置 innodb_force_recovery可以使 srv_force_recovery != 0 ,那么 validate = false,即可以跳过表空间校验。实际测试的时候设置 innodb_force_recovery =1,也就是强制恢复跳过坏页,就可以跳过校验,然后重启就是正常启动了。通过这种临时方式可以避免崩溃恢复后非常耗时的表空间校验过程,快速启动 MySQL,个人目前暂时未发现有什么隐患。2 使用共享表空间替代独立表空间这样就不需要打开 N 个 ibd 文件了,只需要打开一个 ibdata 文件即可,大大节省了校验时间。自从听了姜老师讲过使用共享表空间替代独立表空间解决 drop 大表时性能抖动的原理后,感觉共享表空间在很多业务环境下,反而更有优势。
临时冒出另外一种解决想法,即用 GDB 调试崩溃恢复,通过临时修改 validate 变量值让 MySQL 跳过表空间验证过程,然后让 MySQL 正常关闭,重新启动就可以正常启动了。但是实际测试发现,如果以 debug 模式运行,确实可以临时修改 validate 变量,跳过表空间验证过程,但是 debug 模式下代码运行效率大打折扣,反而耗时更长。而以非 debug 模式运行,则无法修改 validate 变量,想法破灭。
在使用独立表空间的情况下,如果不慎使得innodb存储引擎的元数据文件ibdata损坏,我们还可以挽救宝贵的数据因为在innodb使用独立表空间的情况下,ibdata文件会记录每个innodb表的id,只要使得ibd中的表id和ibdata文件中记录的表id相同,就能够打开表,读取到数据
#创建表
CREATE TABLE `ibdtest` ( `id` int(11) NOT NULL AUTO_INCREMENT, `fid` int(11) NOT NULL COMMENT '表b中的id', `content` char(255) NOT NULL COMMENT ' *** 作内容,系统生成', `mark` char(255) NOT NULL COMMENT '备注', PRIMARY KEY (`id`)) ENGINE=InnoDB DEFAULT CHARSET=utf8
#添加数据INSERT ibdtest (fid,content,mark) VALUES (1,'1','1'),(2,'2','2');SELECT FROM ibdtest;
以上就是关于求助:关于linux下的MySQL数据恢复问题全部的内容,包括:求助:关于linux下的MySQL数据恢复问题、ibdata1数据库如何恢复、系统崩溃后,关于MYSQL恢复数据库的问题!求救啊!等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)