Xtrabackup备份、还原、恢复Mysql操作大全

环境:CentOS 6.7  + Mysql 5.7.19 + Xtraback 2.4.8

innobackupex常用参数:
--user=USER                     指定备份用户,不指定的话为当前系统用户
--password=PASSWD               指定备份用户密码
--port=PORT                     指定数据库端口
--defaults-group=GROUP-NAME     在多实例的时候使用
--host=HOST                     指定备份的主机,可以为远程数据库服务器
--apply-log                     回滚日志
--database                      指定需要备份的数据库,多个数据库之间以空格分开
--defaults-file                 指定mysql的配置文件
--copy-back                     将备份数据复制回原始位置
--incremental                   增量备份,后面跟要增量备份的路径
--incremental-basedir=DIRECTORY 增量备份时使用指向上一次的增量备份所在的目录
--incremental-dir=DIRECTORY     增量备份还原的时候用来合并增量备份到全量,用来指定全备路径
--redo-only                     对增量备份进行合并
--rsync                         加快本地文件传输,适用于non-InnoDB数据库引擎。不与--stream共用
--no-timestamp                  生成的备份文件不以时间戳为目录.

示例组1:全备还原

#数据目录:/data/mysql
$ mkdir -pv /backup/3306/20171107/full
#本地 单实例 全量备份
$ innobackupex --defaults-file=/etc/my.cnf  --user=root --password=123456 --socket=/tmp/mysql.sock --no-timestamp  --parallel=4  /backup/3306/20171107/full
#还原
$ innobackupex --apply-log  /backup/3306/20171107/full
$ service mysqld stop
$ mv /data/mysql  /data/mysql_bak_201711071    ##备份原数据目录
$ mkdir -pv /data/mysql
$ innobackupex --copy-back  /backup/3306/20171107/full
$ chown -R mysql:mysql /data/mysql
$ service mysqld start 

示例组2:增量还原

#数据目录:/data/mysql
$ mkdir -pv /backup/3306/20171107/{full,inc1,inc2,inc3}
#本地 单实例 全量备份
$ innobackupex --defaults-file=/etc/my.cnf  --user=root --password=123456 --socket=/tmp/mysql.sock --no-timestamp  --parallel=4  /backup/3306/20171107/full
#本地 单实例 增量备份1
$ mysql  -S /tmp/mysql.sock  -uroot -p123456 -e "create table tpccdb.tb2(col1 varchar(16));"
$ mysql  -S /tmp/mysql.sock  -uroot -p123456 -e "insert into  tpccdb.tb2 values(‘1‘),(‘2‘),(‘3‘),(‘第一次插入结束‘);"
$ innobackupex --defaults-file=/etc/my.cnf  --user=root  --password=123456  --socket=/tmp/mysql.sock --no-timestamp  --parallel=4  --incremental-basedir=/backup/3306/20171107/full  --incremental /backup/3306/20171107/inc1
#本地 单实例 增量备份2
$ mysql  -S /tmp/mysql.sock  -uroot -p123456 -e "insert into  tpccdb.tb2 values(‘4‘),(‘5‘),(‘6‘),(‘第二次插入结束‘);"
$ innobackupex --defaults-file=/etc/my.cnf  --user=root  --password=123456  --socket=/tmp/mysql.sock --no-timestamp  --parallel=4  --incremental-basedir=/backup/3306/20171107/inc1  --incremental /backup/3306/20171107/inc2
#本地 单实例 增量备份3
$ mysql  -S /tmp/mysql.sock  -uroot -p123456 -e "insert into  tpccdb.tb2 values(‘7‘),(‘8‘),(‘9‘),(‘第三次插入结束‘);"
$ innobackupex --defaults-file=/etc/my.cnf  --user=root  --password=123456  --socket=/tmp/mysql.sock --no-timestamp  --parallel=4  --incremental-basedir=/backup/3306/20171107/inc2  --incremental /backup/3306/20171107/inc3
#还原
$ innobackupex --apply-log  --redo-only /backup/3306/20171107/full
$ innobackupex --apply-log  --redo-only /backup/3306/20171107/full --incremental-dir=/backup/3306/20171107/inc1
$ innobackupex --apply-log  --redo-only /backup/3306/20171107/full --incremental-dir=/backup/3306/20171107/inc2
$ innobackupex --apply-log              /backup/3306/20171107/full --incremental-dir=/backup/3306/20171107/inc3
$ innobackupex --apply-log  /backup/3306/20171107/full
$ service mysqld stop
$ mv /data/mysql  /data/mysql_bak_201711072    ##备份原数据目录
$ mkdir -pv /data/mysql
$ innobackupex --copy-back  /backup/3306/20171107/full
$ chown -R mysql:mysql /data/mysql
$ service mysqld start
$ mysql  -S /tmp/mysql.sock  -uroot -p123456 -e "select * from tpccdb.tb2;"

示例组3:完全&定点&误操作恢复

#数据目录:/data/mysql
$ mkdir -pv /backup/3306/20171107/{full,inc1,inc2}
#本地 单实例 全量备份
$ innobackupex --defaults-file=/etc/my.cnf  --user=root --password=123456 --socket=/tmp/mysql.sock --no-timestamp  --parallel=4  /backup/3306/20171107/full
#本地 单实例 增量备份1
$ mysql  -S /tmp/mysql.sock  -uroot -p123456 -e "create table tpccdb.tb3(col1 varchar(16));"
$ mysql  -S /tmp/mysql.sock  -uroot -p123456 -e "insert into  tpccdb.tb3 values(‘1‘),(‘2‘),(‘3‘),(‘第一次插入结束‘);"
$ innobackupex --defaults-file=/etc/my.cnf  --user=root  --password=123456  --socket=/tmp/mysql.sock --no-timestamp  --parallel=4  --incremental-basedir=/backup/3306/20171107/full  --incremental /backup/3306/20171107/inc1
#本地 单实例 增量备份2
$ mysql  -S /tmp/mysql.sock  -uroot -p123456 -e "insert into  tpccdb.tb3 values(‘4‘),(‘5‘),(‘6‘),(‘第二次插入结束‘);"
$ innobackupex --defaults-file=/etc/my.cnf  --user=root  --password=123456  --socket=/tmp/mysql.sock --no-timestamp  --parallel=4  --incremental-basedir=/backup/3306/20171107/inc1  --incremental /backup/3306/20171107/inc2

$ mysql  -S /tmp/mysql.sock  -uroot -p123456 -e "insert into  tpccdb.tb3 values(‘7‘),(‘8‘),(‘9‘),(‘第三次插入结束‘);"  ##二进制日志恢复
$ mysql  -S /tmp/mysql.sock  -uroot -p123456 -e "flush logs;"
$ mysql  -S /tmp/mysql.sock  -uroot -p123456 -e "insert into  tpccdb.tb3 values(‘10‘),(‘11‘),(‘12‘),(‘第四次插入结束‘);"
$ mysql  -S /tmp/mysql.sock  -uroot -p123456 -e "flush logs;"
$ mysql  -S /tmp/mysql.sock  -uroot -p123456 -e "insert into  tpccdb.tb3 values(‘13‘),(‘14‘),(‘15‘),(‘第五次插入结束‘);" 

#恢复
$ innobackupex --apply-log  --redo-only /backup/3306/20171107/full
$ innobackupex --apply-log  --redo-only /backup/3306/20171107/full --incremental-dir=/backup/3306/20171107/inc1
$ innobackupex --apply-log              /backup/3306/20171107/full --incremental-dir=/backup/3306/20171107/inc2
$ innobackupex --apply-log  /backup/3306/20171107/full
$ cat /backup/3306/20171107/inc2/xtrabackup_binlog_info  ##获取最后一次备份的LSN
## mysql-bin.000004        1707
$ ll -t /data/mysql/mysql-bin*   ##查看有多少个需要导入的二进制文件
-rw-r----- 1 mysql mysql      461 Nov  7 06:22 /data/mysql/mysql-bin.000006
-rw-r----- 1 mysql mysql      485 Nov  7 06:21 /data/mysql/mysql-bin.000005
-rw-r----- 1 mysql mysql     2035 Nov  7 06:20 /data/mysql/mysql-bin.000004

$ mysqlbinlog  --start-position=1707 /data/mysql/mysql-bin.000004 -vv >> /tmp/load.sql
$ mysqlbinlog                        /data/mysql/mysql-bin.000005 -vv >> /tmp/load.sql
$ mysqlbinlog                        /data/mysql/mysql-bin.000006 -vv >> /tmp/load.sql    ##完全恢复 

#$ mysqlbinlog  --stop-position=407   /data/mysql/mysql-bin.000006 -vv >> /tmp/load.sql   ##指定点恢复

#$ mysqlbinlog   --stop-position=407   /data/mysql/mysql-bin.000006 -vv >> /tmp/load.sql   ##误删除恢复(误操作前停止)
#$ mysqlbinlog   --start-position=1108 /data/mysql/mysql-bin.000006 -vv >> /tmp/load.sql   ##误删除恢复(误操作后继续) 

$ service mysqld stop
$ mv /data/mysql  /data/mysql_bak_201711073    ##备份原数据目录
$ mkdir -pv /data/mysql
$ innobackupex --copy-back  /backup/3306/20171107/full
$ chown -R mysql:mysql /data/mysql
$ /usr/local/mysql/bin/mysqld start  --skip-... (关系二进制日志,只需要SUPER权限登录)

$ mysql -uroot -p123456
mysql> source  /tmp/load.sql
$ service mysqld stop
$ /usr/local/mysql/bin/mysqld start

原文地址:https://www.cnblogs.com/shamo89/p/9767310.html

时间: 2024-10-27 17:15:11

Xtrabackup备份、还原、恢复Mysql操作大全的相关文章

xtrabackup备份还原MySQL数据库

原文:xtrabackup备份还原MySQL数据库 mysqldump 备份鉴于其自身的某些特性(锁表,本质上备份出来insert脚本或者文本,不支持差异备份),不太适合对实时性要求比较高的情况Xtrabackup可以解决mysqldump存在的上述的一些问题,生产环境应用的也会更多一些.本文简单测试一下Xtrabackup对MySQL数据库的备份还原操作. 本着先把功能先撸起来再深入细节的原则,粗略地实现了一个备份还原,并未深入细节. 网上有不少xtrabackup的文章,因为环境不一样,有些

Qt中使用QProcess备份和恢复Mysql数据库

分类: Qt2011-02-18 21:35 1395人阅读 评论(3) 收藏 举报 qtmysql数据库windowspathcmd . 使用Qt做MySQL数据库开发,遇到需要备份.还原数据库的问题. MySQL中没有提供将数据库备份成.sql文件的SQL语句,而是提供了一个mysqldump.exe工具来完成这个功能. 没有SQL语句,QSqlQuery就用不成了,决定改用QProcess实现. . 但是在Qt中使用QProcess::execute()方法怎样都导不出数据来, 更郁闷的是

xtrabackup备份方式搭建mysql slave

以前mysql搭建新备库都是在现在业务较小的备库上停止同步或停止数据库,然后拷贝数据库到新备库,配置好新备库后,再开启同步或数据库.然而,这次没有空闲备库用来搭新备库.  需要从一个业务繁忙的数据库中搭建一个新备库,对系统延时要求比较高,所以同步和数据库都不能停.所以我们用了percona的 xtrabackup备份工具.  因为这个备份要作为备库,所以用了–slave-info参数,备份完成后会生成一个对应主库的binlog日志的文件,用于配置同步.为了保证数据一致性,使用了–slave-in

Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁

Python进阶----pymysql的安装与使用,mysql数据库的备份和恢复,mysql的事务和锁 一丶安装 pip install PyMySQL 二丶pymysql连接数据库 ### 语法: import pymysql # 导入py模块 conn= pymysql.connect("数据库ip","用户","密码","数据库" ) # 打开数据库连接 cursor.execute("SELECT VERSI

xtrabackup 全备份,增量备份,恢复 mysql数据库

Xtrabackup使用指南 InnoDB数据备份工具 Xtrabackup是一个对InnoDB做数据备份的工具,支持在线热备份(备份时不影响数据读写,也就是不加锁),是商业备份工具InnoDB Hotbackup的一个很好的替代品 一.Xtrabackup介绍  A.Xtrabackup是什么 Xtrabackup是一个对InnoDB做数据备份的工具,支持在线热备份(备份时不影响数据读写),是商业备份工具InnoDB Hotbackup的一个很好的替代品. Xtrabackup有两个主要的工具

Mysql中-Xtrabackup备份和恢复应用

关于Xtrabackup(又或innobackupex)的介绍,详细参考官方文档 Xtrabackup安装指南 文件准备 [[email protected] ~]# cd percona-xtrabackup/ [[email protected] percona-xtrabackup]# ls libev-4.15-1.el6.rf.x86_64.rpm percona-release-0.1-4.noarch.rpm percona-xtrabackup-24-2.4.4-1.el7.x8

xtrabackup备份还原mariadb数据库

一.xtrabackup 简介 xtrabackup 是由percona公司开源免费的数据库热备软件,它能对InnoDB数据库和XtraDB存储引擎的数据库非阻塞地备份,对于myisam的备份同样需要加表锁.mysqldump备份方式是通过用户名密码连接到数据库,将其要备份的数据库用SQL语句的形式输出到标准输出,这种逻辑备份的方式最大的缺点是备份和恢复的速度较慢,如果数据库过大,mysqldump备份就显得力不从心了.这时选择用xtrabackup来备份就能很好解决数据库过大而导致备份过慢的问

xtrabackup备份还原的具体操作过程

一:安装: 地址:https://www.percona.com/software/mysql-database/percona-xtrabackup 版本:2.3.2 注意:可能依赖perl-DBD-mysql 安装:yum -y localinstall percona-xtrabackup-2.3.2-1.el6.i686.rpm 一:授权 MariaDB [mysql]> grant reload,lock tables,replication client on *.* to 'bku

使用binlog日志, XtraBackup备份工具 ,MySQL AB复制

使用binlog日志 1.1 问题 利用binlog恢复库表,要求如下: 启用binlog日志 创建db1库tb1表,插入3条记录 删除tb1表中刚插入的3条记录 使用mysqlbinlog恢复删除的3条记录 1.2 步骤 实现此案例需要按照如下步骤进行. 步骤一:启用binlog日志 1)调整/etc/my.cnf配置,并重启服务 [[email protected] ~]# vim /etc/my.cnf [mysqld] .. .. log-bin-index=mysql-bin