从完整备份恢复单个innodb表
现在大多数同学在线上采取的备份策略都是xtrabackup全备+binlog备份,那么当某天某张表意外的删除那么如何从xtrabackup全备中恢复呢?从mysql 5.6版本开始,支持可移动表空间(Transportable Tablespace)那么利用这个功能就可以实现单表的恢复,同样利用这个功能还可以把innodb表移动到另外一台服务器上。可以参考:https://yq.aliyun.com/articles/59271
下面进行从xtrabackup全备恢复单表的测试。
1. 开启了参数innodb_file_per_table
2. 安装工具:mysql-utilities,其中mysqlfrm可以读取表结构。
yum install mysql-utilities -y
查看原表中的数据:
mysql> select * from yayun.t1;
+------+------+
| id | name |
+------+------+
| 1 | aa |
| 2 | bb |
| 3 | cc |
| 4 | dd |
+------+------+
4 rows in set (0.00 sec) mysql>
执行备份:
innobackupex --defaults-file=/data/mysql//my.cnf --user=root --password= --sock=/data/mysql//mysqltmp/mysql.sock /data/
apply-log
innobackupex --defaults-file=/data/mysql//my.cnf --apply-log /data/--22_16--/
删除t1表:
mysql> use yayun
Database changed
mysql> drop table t1;
Query OK, 0 rows affected (0.13 sec) mysql>
读取表结构
mysqlfrm --diagnostic /data/--22_16--/yayun/t1.frm
输出:
# Reading .frm file for /data/--22_16--/yayun/t1.frm:
# The .frm file is a TABLE.
# CREATE TABLE Statement: CREATE TABLE `yayun`.`t1` (
`id` int() DEFAULT NULL,
`name` char() DEFAULT NULL
) ENGINE=InnoDB; #...done.
建表:
mysql> use yayun
Database changed
mysql> CREATE TABLE `yayun`.`t1` (
-> `id` int(11) DEFAULT NULL,
-> `name` char(180) DEFAULT NULL
-> ) ENGINE=InnoDB;
Query OK, 0 rows affected (0.08 sec) mysql>
加一个写锁,确保安全
mysql> lock tables t1 write;
Query OK, 0 rows affected (0.00 sec) mysql>
丢弃表空间:
mysql> alter table t1 discard tablespace;
Query OK, 0 rows affected (0.07 sec) mysql>
从备份中拷贝ibd文件,并且修改权限
[root@db_server_yayun_01 ~]# cp /data/--22_16--/yayun/t1.ibd /data/mysql//data/yayun/
[root@db_server_yayun_01 ~]# chown -R mysql.mysql /data/mysql//data/yayun/t1.ibd
载入表空间:
mysql> alter table t1 import tablespace;
Query OK, 0 rows affected, 1 warning (0.15 sec) mysql> show warnings;
+---------+------+------------------------------------------------------------------------------------------------------------------------------------------+
| Level | Code | Message |
+---------+------+------------------------------------------------------------------------------------------------------------------------------------------+
| Warning | 1810 | InnoDB: IO Read error: (2, No such file or directory) Error opening './yayun/t1.cfg', will attempt to import without schema verification |
+---------+------+------------------------------------------------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec) mysql>
这里有警告,可以忽略。详情可以看:https://yq.aliyun.com/articles/59271
查询数据是否一致:
mysql> select * from t1;
+------+------+
| id | name |
+------+------+
| 1 | aa |
| 2 | bb |
| 3 | cc |
| 4 | dd |
+------+------+
4 rows in set (0.00 sec) mysql>
最后解锁:
mysql> unlock tables;
Query OK, 0 rows affected (0.00 sec) mysql>
参考文章:
从完整备份恢复单个innodb表的更多相关文章
- 基于Xtrabackup恢复单个innodb表
		Preface We all know that Xtrabackup is a backup tool of percona for innodb or Xtradb.It's us ... 
- MySQL 备份恢复(导入导出)单个 innodb表
		MySQL 备份恢复单个innodb表呢,对于这种恢复我们我们很多朋友都不怎么了解了,下面一起来看一篇关于MySQL 备份恢复单个innodb表的教程 在实际环境中,时不时需要备份恢复单个或多个表(注 ... 
- MySQL另类的备份恢复方法——innodb可传输表空间
		Preface There're many ways in backing up or migrating data from one server to another one.Lo ... 
- mysql备份恢复数据库据/表
		备份单个数据库,只备份表,如要恢复,必须先创建一个数据库[root@s]# mysqldump -u root -p dbname1 > dbname1.sql[root@s]# mysql - ... 
- linux 通过scp 复制备份恢复mysql数据表
		最近客户有个需求,小弟对于运维的东西也是半瓶醋,所以就果断的摸索了下.折磨了一个晚上终于算是搞定了.因为是两个不同的服务器,本来想用ftp,无奈小弟不是很熟悉,所以就用了scp,但是scp有个问题就是 ... 
- 从xtrabackup备份恢复单表
		目前对MySQL比较流行的备份方式有两种,一种上是使用自带的mysqldump,另一种是xtrabackup,对于数据时大的环境,普遍使用了xtrabackup+binlog进行全量或者增量备份,那么 ... 
- 从xtrabackup备份恢复单表【转】
		目前对MySQL比较流行的备份方式有两种,一种上是使用自带的mysqldump,另一种是xtrabackup,对于数据时大的环境,普遍使用了xtrabackup+binlog进行全量或者增量备份,那么 ... 
- 在线热备份数据库之innobackupex 完整备份InnoDB
		在线热备份数据库innobackupex 完整备份InnoDB XtraBackup xtrabackup C程序,支持InnoDB/XtraDB innobackupex : 以Perl脚本封装xt ... 
- MySQL基于LVM快照的备份恢复(临时)
		目录1.数据库全备份2.准备LVM卷3.数据恢复到LVM卷4.基于LVM快照备份数据5.数据灾难恢复6.总结 写在前面:测试环境中已安装有mysql 5.5.36数据库,但数据目录没有存放在LVM卷, ... 
随机推荐
- 【MySQL】-2 函数、分组、子查询、联合查询
			函数 Mysql的函数特性没有SQL可移植性强. 大多数情况下支持的函数: 处理文本串的函数: RTrim():处理列值右边的空格 LTrim():处理列值左边的空格 Trim():处理列值的左右 ... 
- 修改maven 本地仓库,加入阿里云
			阿里云仓库服务 http://maven.aliyun.com/mvn/view maven加入阿里云服务 在maven conf文件下修改settings.xml 修改本地仓库<localR ... 
- virtual关键字
			出于多态的考虑,为了覆盖, 子类同名覆盖函数(函数名.参数.返回值都相同) virtual void print(): 这也许会使人联想到函数的重载,但稍加对比就会发现两者是完全不同的:(1)重载的几 ... 
- 请求转发(forward)和请求重定向(redirect)的区别(转)
			作者:@haimishasha本文为作者原创,转载请注明出处:https://www.cnblogs.com/haimishasha/p/5952129.html 用户向服务器发送了一次HTTP请求, ... 
- PLSQL基础知识-图片
			什么是PL/SQL? 
- mybatis中使用常量
			mybatis的mapper文件中项要使用常量的话${@类的全称路劲@常量名称} 
- Android ------------------ 带边框的圆角矩形
			<?xml version="1.0" encoding="utf-8"?><shape xmlns:android="http:/ ... 
- 关于Linux MongoDB的安装
			前一篇博文讲解了如何安装与配置MongoDB的windows版,本篇博文接着上一篇讲解如何在Linux系统中安装与配置MongoDB,为了演示,我问同事要了它的云服务器用于演示,当然我自己也有,但是已 ... 
- Android 监听耳机的插拔事件
			一般采用的是动态监听的方式来实现的: package com.renhui.ej; import android.content.BroadcastReceiver; import android.c ... 
- OpenStack-Ocata版+CentOS7.6 云平台环境搭建 — 8.仪表盘 Dashboard(horizon)安装配置
			仪表盘Dashboard(horizon)是一个web接口,使得云平台管理员以及用户可以管理不同的Openstack资源以及服务.这个部署示例使用的是 Apache Web 服务器. 节点配置信息说明 ... 
