一次数据库恢复操作

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

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

 

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文件恢复过来。需要进一步测试。。。

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值