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;
即可查看数据已经恢复到新表中,然后从新表中找出删除的数据,同步到线上环境即可。