percona-xtrabackup恢复mysql表数据

percona-xtrabackup恢复mysql表数据


在项目上,一个同事不小心删除了线上环境某个表的部分数据,虽然不是关键数据,但是数据丢失也得恢复。比较好的是,线上数据库使用了xtrabackup备份了mysql数据,一个星期一次全量备份,每天增量备份,保留两周备份数据。而删除的数据正好是历史数据,所以找到一个全量备份的数据,把丢失的数据查找出来再导入进去。因为这里备份不是实时备份的,所以没办法直接恢复。而且以前也没做过这种数据丢失之后再恢复的工作,所以就各种百度找方案,顺便记录一下。

1.基础知识

MySQL的相关文件都会存放在安装目录下data文件夹下,进入data目录会包含相应数据库的文件夹,打开文件夹,会看到每个表的.frm和.ibd文件以及db.opt文件。因为线上环境数据库表都是用innodb引擎所以只有这两种文件,db.opt文件记录该库的默认字符集编码和字符集排序规则,.frm与表相关的元数据信息,.idb是InnoDB表的数据文件。

2. 准备

xtrabackup全量备份会拷贝所有的.frm和.ibd文件。因为我这边已经有备份文件了,所以可以直接用对应表的.frm和.ibd文件。

关于xtrabackup安装,全量备份和增量备份数据库,可以参考下面的博客:
percona-xtrabackup恢复mysql主从同步

3. 安装mysql-utilities

yum install mysql-utilities -y

或者

wget -c https://downloads.mysql.com/archives/get/file/mysql-utilities-1.6.5.tar.gz
tar -xvf mysql-utilities-1.6.5.tar.gz
cd mysql-utilities-1.5.3
python ./setup.py build
python ./setup.py install

因为不是直接再原表上直接恢复,所以准备了一个干净的数据库。使用如下命令,在全量备份中找到对应表的.frm文件,会打印出表结构

mysqlfrm --server=${user}:${password}@${host}:{port} ${table}.frm --user=root --port=3307 

把表结构导入到准备好的赶紧的数据库中。

丢弃表空间。在准备好的干净的数据库中执行如下sql语句:

alter table ${table} discard tablespace;  # ${table}对应的表

从备份中拷贝ibd文件到新数据库的数据库文件下,通常是安装目录下的data文件夹下对应库文件夹下,并且修改权限

cp ${table}.ibd  ${mysql安装目录}/data/${database}/
chown -R mysql.mysql ${mysql安装目录}/data/${database}/${table}.ibd

一定要修改权限,不然会报如下错误:

Error Code:1812. Tablespace is missing for table ${table}

在干净的数据库中执行如下sql语句:

alter table ${table} import tablespace;

即可查看数据已经恢复到新表中,然后从新表中找出删除的数据,同步到线上环境即可。

参考:
使用Xtrabackup完整备份中恢复单表
MySQL入门篇(七)之Xtrabackup备份与恢复

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值