一次数据库恢复操作

手贱加眼斜不小心把正在使用的一个库的表给覆盖了而且是非常干净那种。

值得庆幸的是有备份,于是开始恢复!

xtrabackup备份的,更幸运的是今天正好有一份全量的备份,凌晨刚备的,所以省的再准备增量文件了。

记录过程如下:

停mysql进程

mv  data  databak  #把现有数据目录备份

mkdir data    #创建一个新的数据目录

准备全量文件

/usr/local/xtrabackup/bin/xtrabackup --prepare --target-dir=/backup/DB3308/full/2019-04-12_01-30-01/

成功后恢复备份到实例数据目录

/usr/local/xtrabackup/bin/xtrabackup --copy-back --target-dir=/backup/DB3308/full/2019-04-12_01-30-01 --datadir=/data/mysql3308/data 

完成后启动mysql

/bin/sh /usr/local/mysql5721/bin/mysqld_safe --defaults-file=/data/mysql3308/my3308.cnf

然后这里报错:

2019-04-12T05:23:23.524942Z 0 [ERROR] InnoDB: The innodb_system data file 'ibdata1' must be writable
2019-04-12T05:23:23.524984Z 0 [ERROR] InnoDB: The innodb_system data file 'ibdata1' must be writable
2019-04-12T05:23:23.524995Z 0 [ERROR] InnoDB: Plugin initialization aborted with error Generic error
2019-04-12T05:23:24.125643Z 0 [ERROR] Plugin 'InnoDB' init function returned error.
2019-04-12T05:23:24.125687Z 0 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed.
2019-04-12T05:23:24.125702Z 0 [ERROR] Failed to initialize builtin plugins.
2019-04-12T05:23:24.125710Z 0 [ERROR] Aborting

ibdata1文件权限不对

chmod 755 ibdata1

chown mysql.mysql /data/mysql3308/ -R

再次启动

依然报错:

2019-04-12T05:25:05.202146Z 0 [ERROR] InnoDB: Unable to open undo tablespace './/undo001'.
2019-04-12T05:25:05.202159Z 0 [ERROR] InnoDB: Plugin initialization aborted with error Generic error
2019-04-12T05:25:05.802746Z 0 [ERROR] Plugin 'InnoDB' init function returned error.
2019-04-12T05:25:05.802777Z 0 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed.
2019-04-12T05:25:05.802792Z 0 [ERROR] Failed to initialize builtin plugins.
2019-04-12T05:25:05.802802Z 0 [ERROR] Aborting
 

undo文件找不到,这里犯了一个错误,把databak下的undo文件复制回来了,结果再启动mysql的时候虽然能启动,但是mysql依然在报错。

PS: 后经确认xtrabackup在备份的时候确实备份undo文件了

xtrabackup在恢复的时候不知什么原因,没有把备份中的undo文件恢复过来。需要进一步测试。。。

经同事确认数据在,日志报错一段后停止。

发布了91 篇原创文章 · 获赞 25 · 访问量 25万+

猜你喜欢

转载自blog.csdn.net/kevin3101/article/details/89235236