Xtrabackup2.4.8备份、还原、恢复Mysql5.7.19实操
环境: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///full
#本地 单实例 全量备份
$ innobackupex --defaults-file=/etc/my.cnf --user=root --password= --socket=/tmp/mysql.sock --no-timestamp --parallel= /backup///full
#还原
$ innobackupex --apply-log /backup///full
$ service mysqld stop
$ mv /data/mysql /data/mysql_bak_201711071 ##备份原数据目录
$ mkdir -pv /data/mysql
$ innobackupex --copy-back /backup///full
$ chown -R mysql:mysql /data/mysql
$ service mysqld start
示例组2:增量还原
#数据目录:/data/mysql
$ mkdir -pv /backup///{full,inc1,inc2,inc3}
#本地 单实例 全量备份
$ innobackupex --defaults-file=/etc/my.cnf --user=root --password= --socket=/tmp/mysql.sock --no-timestamp --parallel= /backup///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= --socket=/tmp/mysql.sock --no-timestamp --parallel= --incremental-basedir=/backup///full --incremental /backup///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= --socket=/tmp/mysql.sock --no-timestamp --parallel= --incremental-basedir=/backup///inc1 --incremental /backup///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= --socket=/tmp/mysql.sock --no-timestamp --parallel= --incremental-basedir=/backup///inc2 --incremental /backup///inc3
#还原
$ innobackupex --apply-log --redo-only /backup///full
$ innobackupex --apply-log --redo-only /backup///full --incremental-dir=/backup///inc1
$ innobackupex --apply-log --redo-only /backup///full --incremental-dir=/backup///inc2
$ innobackupex --apply-log /backup///full --incremental-dir=/backup///inc3
$ innobackupex --apply-log /backup///full
$ service mysqld stop
$ mv /data/mysql /data/mysql_bak_201711072 ##备份原数据目录
$ mkdir -pv /data/mysql
$ innobackupex --copy-back /backup///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///{full,inc1,inc2}
#本地 单实例 全量备份
$ innobackupex --defaults-file=/etc/my.cnf --user=root --password= --socket=/tmp/mysql.sock --no-timestamp --parallel= /backup///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= --socket=/tmp/mysql.sock --no-timestamp --parallel= --incremental-basedir=/backup///full --incremental /backup///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= --socket=/tmp/mysql.sock --no-timestamp --parallel= --incremental-basedir=/backup///inc1 --incremental /backup///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///full
$ innobackupex --apply-log --redo-only /backup///full --incremental-dir=/backup///inc1
$ innobackupex --apply-log /backup///full --incremental-dir=/backup///inc2
$ innobackupex --apply-log /backup///full
$ cat /backup///inc2/xtrabackup_binlog_info ##获取最后一次备份的LSN
## mysql-bin.
$ ll -t /data/mysql/mysql-bin* ##查看有多少个需要导入的二进制文件
-rw-r----- mysql mysql Nov : /data/mysql/mysql-bin.
-rw-r----- mysql mysql Nov : /data/mysql/mysql-bin.
-rw-r----- mysql mysql Nov : /data/mysql/mysql-bin. $ mysqlbinlog --start-position= /data/mysql/mysql-bin. -vv >> /tmp/load.sql
$ mysqlbinlog /data/mysql/mysql-bin. -vv >> /tmp/load.sql
$ mysqlbinlog /data/mysql/mysql-bin. -vv >> /tmp/load.sql ##完全恢复 #$ mysqlbinlog --stop-position= /data/mysql/mysql-bin. -vv >> /tmp/load.sql ##指定点恢复 #$ mysqlbinlog --stop-position= /data/mysql/mysql-bin. -vv >> /tmp/load.sql ##误删除恢复(误操作前停止)
#$ mysqlbinlog --start-position= /data/mysql/mysql-bin. -vv >> /tmp/load.sql ##误删除恢复(误操作后继续) $ service mysqld stop
$ mv /data/mysql /data/mysql_bak_201711073 ##备份原数据目录
$ mkdir -pv /data/mysql
$ innobackupex --copy-back /backup///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
Xtrabackup2.4.8备份、还原、恢复Mysql5.7.19实操的更多相关文章
- Xtrabackup2.4.8备份、还原、恢复Mysql5.7.19实操(网络拷贝)
环境:CentOS 6.7 + Mysql 5.7.19 + Xtraback 2.4.8 innobackupex常用参数: --user=USER 指定备份用户,不指定的话为当前系统用户 --p ...
- python脚本:在Ubuntu16系统上基于xtrabackup2.4和mysql5.7实现数据库数据的自动化备份和恢复,亲测有效!
1 安装教程 官网安装教程:https://www.percona.com/doc/percona-xtrabackup/2.4/installation/apt_repo.html -------- ...
- MongoDB整库备份与还原以及单个collection备份、恢复方法
mongodb数据库维护离不开必要的备份.恢复操作,而且一般不会出错,所以我们在使用的时候大部分时候使用备份和恢复操作就可以了 mongodump.exe备份的原理是通过一次查询获取当前服务器快照 ...
- centos环境下使用percona-xtrabackup对mysql5.6数据库innodb和myisam进行快速备份及恢复
centos环境下使用percona-xtrabackup对mysql5.6数据库innodb和myisam进行快速备份及恢复 有时候我们会碰到这样的业务场景: 1.将大的数据库恢复到本地进行业务测试 ...
- (4.10)mysql备份还原——利用binlog+全备恢复误删表【不推荐使用】
关键误操作:mysql误删除 1.备份+binlog恢复数据 [1.1]场景:不小心误删除某张表 [1.2]解决方法:在另外一台机器,恢复全库+日志,然后导出删除的表,再插入会生产库. [1.3]案例 ...
- (4.16)mysql备份还原——物理备份之XtraBackup实践
关键词:XtraBackup实践,物理备份,xtrabackup备份,innobackupex备份 [1]如何使用? [3]系列:innobackupex --help |more [4]系列:xtr ...
- xtrabackup备份还原mariadb数据库
一.xtrabackup 简介 xtrabackup 是由percona公司开源免费的数据库热备软件,它能对InnoDB数据库和XtraDB存储引擎的数据库非阻塞地备份,对于myisam的备份同样需要 ...
- 我的MYSQL学习心得(十四) 备份和恢复
我的MYSQL学习心得(十四) 备份和恢复 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) ...
- 我的MYSQL学习心得 备份和恢复(详细)
备份 逻辑备份方法 使用MYSQLDUMP命令备份 MYSQLDUMP是MYSQL提供的一个非常有用的数据库备份工具.mysqldump命令执行时将数据库备份成一个文本文件, 该文件中实际上包含了多个 ...
随机推荐
- 【iOS】swift 排序Sort函数用法(包含NSDictionary排序)
用了几分钟做的简单翻译 一个例子 直接贴代码,不过多解释 //这是我们的model class imageFile { var fileName = String() var fileID = Int ...
- 函数式编程之foldLeftViaFoldRight
问题来自 Scala 函数式编程 一书的习题, 让我很困扰, 感觉函数式编程有点神学的感觉.后面看懂之后, 又觉得函数式编程所提供的高阶抽象是多么的强大. 这个问题让我发呆了好久, 现在把自己形成的想 ...
- nyoj 公约数和公倍数
公约数和公倍数 时间限制:1000 ms | 内存限制:65535 KB 难度:1 描述 小明被一个问题给难住了,现在需要你帮帮忙.问题是:给出两个正整数,求出它们的最大公约数和最小公倍数. ...
- AngularJS1.X学习笔记7-过滤器
最近参加笔试被虐成狗了,感觉自己的算法太弱了.但是还是先花点事件将这个AngularJS学习完.今天学习filter 一.内置过滤器 (1)过滤单个数据值 <!DOCTYPE html> ...
- 如何排查CPU飙升的Java问题
1. JPS 查看jvm进程 2. 显示线程列表 ps -mp pid -o THREAD,tid,time 找到了耗时最高的线程tid 3. tid转换成16进制 printf "%x\n ...
- jquery 实时监听输入框值变化方法
$('.offers-number').bind('input propertychange', function (a, b) { var value = $(this).val() if (!va ...
- 用C#(.NET Core) 实现简单工厂和工厂方法模式
本文源自深入浅出设计模式. 只不过我是使用C#/.NET Core实现的例子. 前言 当你看见new这个关键字的时候, 就应该想到它是具体的实现. 这就是一个具体的类, 为了更灵活, 我们应该使用的是 ...
- OAuth2.0学习(1-3)OAuth2.0的参与者和流程
OAuth(开放授权)是一个开放标准.允许第三方网站在用户授权的前提下访问在用户在服务商那里存储的各种信息.而这种授权无需将用户提供用户名和密码提供给该第三方网站. OAuth允许用户提供一个令牌给第 ...
- Python之进程
进程 进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础.在早期面向进程设计的计算机结构中,进程是程序的基本执行实体:在当代 ...
- python Django注册页面显示头像
python Django注册页面显示头像(views) def register(request): ''' 注册 :param request: :return: ''' if request.m ...