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
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值