(十一)mysql备份之物理备份xtrabackup
(1)备份介绍
(2)下载安装xtrabackup
官网:https://www.percona.com/downloads/XtraBackup/LATEST/
我选择yum安装,centos版本7
wget http://www.percona.com/downloads/percona-release/redhat/0.1-4/\
percona-release-0.1-4.noarch.rpm
rpm -ivH percona-release-0.1-4.noarch.rpm
yum install percona-xtrabackup-24 -y
(3)完全备份与恢复
1)完全备份
- 创建备份账户
mysql> grant reload,process,lock tables,replication client on *.* to backup@localhost identified by 'backup';
mysql> flush privileges;
创建完全备份目录
mkdir /mysql/backup-full -pv
- 完全备份
方式一:innobackupex --user=backup --password=backup --host=127.0.0.1 /mysql/backup-full/
方式二:innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock /mysql/backup-full/
生成目录:/mysql/backup-full/2018-04-24_11-16-17/
2)完全备份恢复
- 停止服务删除数据目录
systemctl stop mysqld
rm -rf /data/mydata/*
- 恢复
innobackupex --apply-log /mysql/backup-full/2018-04-24_11-16-17/
innobackupex --copy-back /mysql/backup-full/2018-04-24_11-16-17/
- 授权与恢复
chown -R mysql.mysql /data/mydata/
systemctl start mysqld
(4)增量备份与恢复
注意:增量备份目录我这里放在/mysql/目录下,完全备份目录放在/mysql/backup-full/目录下
1)完全增量备份
注意:增量备份目录我这里放在/mysql/目录下,完全备份目录放在/mysql/backup-full/目录下
- 准备环境
mysql> create database testdb;
mysql> create table testdb.test(id int);
mysql> insert into testdb.test values(1);
- 完全备份:4月24日
innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock /mysql/backup-full/
目录下生成:/mysql/backup-full/2018-04-24_12-15-09/
- 第一次增量备份:4月25日增量备份1
修改时间为4月25日:date -s "20180425"
插入数据:mysql> insert into testdb.test values(2);
innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock --incremental /mysql/ --incremental-basedir=完全备份
基准是完全备份:/mysql/backup-full/2018-04-24_12-15-09/
innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock --incremental /mysql/ --incremental-basedir=/mysql/backup-full/2018-04-24_12-15-09/
生成增量备份目录:/mysql/2018-04-25_00-01-14/
- 第二次增量备份:4月26日增量备份2
修改时间为4月26日:date -s "20180426"
再次插入数据:mysql> insert into testdb.test values(3);
innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock --incremental /mysql/ --incremental-basedir=上一次增量备份
基准是上一次增量备份:/mysql/2018-04-25_00-01-14/
innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock --incremental /mysql --incremental-basedir=/mysql/2018-04-25_00-01-14/
生成增量备份目录:/mysql/2018-04-26_00-00-59/
2)增量恢复
- 停止服务删除数据
systemctl stop mysqld
rm -rf /data/mydata/*
- 数据恢复
innobackupex --apply-log --redo-only 完整备份目录
innobackupex --apply-log --redo-only 完整备份目录 --incremental-dir=第一次增量备份目录
innobackupex --apply-log --redo-only 完整备份目录 --incremental-dir=第二次增量备份目录
innobackupex --copy-back 完整备份
innobackupex --apply-log --redo-only /mysql/backup-full/2018-04-24_12-15-09/
innobackupex --apply-log --redo-only /mysql/backup-full/2018-04-24_12-15-09/ --incremental-dir=/mysql/2018-04-25_00-01-14/
innobackupex --apply-log --redo-only /mysql/backup-full/2018-04-24_12-15-09/ --incremental-dir=/mysql/2018-04-26_00-00-59/
innobackupex --copy-back /mysql/backup-full/2018-04-24_12-15-09/
- 目录授权与启动mysql
chown -R mysql.mysql /data/mydata/
systemctl start mysqld
(5)差异备份恢复
注意:差异备份的基准永远根据上一次完全备份
1)差异备份
- 准备环境
mysql> create database testdb;
mysql> create table testdb.test(id int);
mysql> insert into testdb.test values(1);
- 完整备份:20180424(date -s "20180424")
innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock /mysql/backup-full/
生成目录:ll /mysql/backup-full/2018-04-24_00-00-08/
- 插入一条数据
mysql> insert into testdb.test values(2);
- 差异备份1:20180425(date -s "20180425")
innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock --incremental /mysql/ --incremental-basedir=完整备份目录
innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock --incremental /mysql/ --incremental-basedir=/mysql/backup-full/2018-04-24_00-00-08/
生成目录:/mysql/2018-04-25_00-01-51/
- 插入一条数据
mysql> insert into testdb.test values(3);
- 差异备份2:20180426(date -s "20180426")
innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock --incremental /mysql/ --incremental-basedir=完整备份目录
innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock --incremental /mysql/ --incremental-basedir=/mysql/backup-full/2018-04-24_00-00-08/
生成目录:/mysql/2018-04-26_00-00-15/
2)差异备份恢复
- 停止数据和删除数据目录
systemctl stop mysqld
rm -rf /data/mydata/*
- 数据恢复
innobackupex --apply-log --redo-only 完整备份目录
innobackupex --apply-log --redo-only 完整备份目录 --incremental-dir=某个差异备份目录
innobackupex --copy-back 完整备份目录
innobackupex --apply-log --redo-only /mysql/backup-full/2018-04-24_00-00-08/
innobackupex --apply-log --redo-only /mysql/backup-full/2018-04-24_00-00-08/ --incremental-dir=/mysql/2018-04-26_00-00-15/
innobackupex --copy-back /mysql/backup-full/2018-04-24_00-00-08/
- 目录授权与启动数据库
systemctl start mysqld
chown -R mysql.mysql /data/mydata/
systemctl start mysqld
(十一)mysql备份之物理备份xtrabackup的更多相关文章
- Mysql备份与恢复(1)---物理备份
数据库对企业来说最重要的莫过于其中的数据,所以做好数据库的备份是一个不可或缺的工作.数据库及时备份可以帮助我们在数据库出现异常宕机时及时的使用备份数据进行恢复工作,将因为数据库宕机产生的影响降低到最小 ...
- 说明Oracle数据库逻辑备份和物理备份的方式。
说明Oracle数据库逻辑备份和物理备份的方式. 解答:Oracle备份包括逻辑备份和物理备份. 1).逻辑备份 数据库的逻辑备份包含读一个数据库记录集和将记录集写入文件. a.输出(Export)输 ...
- ORACLE数据库的备份分为物理备份和逻辑备份两种。
物理备份是将实际组成数据库的操作系统文件从一处拷贝到另一处的备份过程,通常是从磁盘到磁带.可以使用 Oracle 的恢复管理器(Recovery Manager,RMAN)或操作系统命令进行数据库的物 ...
- (4.15)mysql备份还原——物理备份之XtraBackup的下载与安装
关键词:mysql物理备份,XtraBackup,XtraBackup安装,XtraBackup下载 实践链接:https://www.cnblogs.com/gered/p/11147193.htm ...
- (4.16)mysql备份还原——物理备份之XtraBackup实践
关键词:XtraBackup实践,物理备份,xtrabackup备份,innobackupex备份 [1]如何使用? [3]系列:innobackupex --help |more [4]系列:xtr ...
- MYSQL的备份与恢复--物理备份xrabackup
目录 1.数据库完整备份与恢复 (1)环境准备 (2)完全备份恢复流程 2.数据库增量备份与恢复 (1)增量和差异概述 (2)增量备份和恢复 3.数据库差异备份与恢复 4.简单命令进行物理备份 5.实 ...
- mysqldump 逻辑备份和物理备份
逻辑备份 逻辑备份是备份sql语句,在恢复的时候执行备份的sql语句实现数据库数据的重现. 工具:mysqldump 特点: 1.可移植性比较强 2.备份和恢复的花费时间长,不适用于大型业务系统 物理 ...
- mysql 开发进阶篇系列 48 物理备份与恢复(xtrabackup 的增量备份与恢复,以及备份总结)
一.增量备份概述 xtrabackup 和innobackupex 二个工具都支持增量备份,这意味着能复制自上次备份以来更改的数据.可以在每个完整备份之间执行许多增量备份,因此,您可以设置一个备份 ...
- MySQL 物理备份工具-xtrabackup
安装 wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo yum -y install perl ...
随机推荐
- IntellIJ IDEA 配置 Git,顺带解决Git Push rejected问题
1.下载便携版本git https://git-scm.com/download/win 弹出的下载取消,重新选择 2.解压自压缩文件. 3.配置IDEA 4.测试 5.配置终端环境shell为bas ...
- 深入了解一下Redis的内存模型!
一.前言 Redis是目前最火爆的内存数据库之一,通过在内存中读写数据,大大提高了读写速度,可以说Redis是实现网站高并发不可或缺的一部分. 我们使用Redis时,会接触Redis的5种对象类型(字 ...
- [POJ 1204]Word Puzzles(Trie树暴搜&AC自己主动机)
Description Word puzzles are usually simple and very entertaining for all ages. They are so entertai ...
- 【NOIP模拟赛】公主的朋友 区间染色问题
这道题大家都用的分块,然而我发现这是一个经典算法:区间染色问题. 我们区间染色时把区间分成若干连续的颜色段,然后我们每次染色删除原来的颜色段插入新的颜色段. 我们发现我们的时间复杂度直接与我们要染色区 ...
- 【bzoj3224】Tyvj 1728 普通平衡树 01Trie姿势+平衡树的四种姿势 :splay,旋转Treap,非旋转Treap,替罪羊树
直接上代码 正所谓 人傻自带大常数 平衡树的几种姿势: AVL Red&Black_Tree 码量爆炸,不常用:SBT 出于各种原因,不常用. 常用: Treap 旋转 基于旋转操作和随机数 ...
- dns服务 很多问题,后续再研究
慕课网:http://www.imooc.com/video/5220 参考:http://jingyan.baidu.com/article/870c6fc32c028eb03fe4be30.htm ...
- 防恶意解析,禁止用IP访问网站的Apache设置
一般来说,网站可以用域名和IP来访问.你的网站可以通过IP直接访问,本来这没什么问题,但是会有些隐患: 由于搜索引擎也会收录你的IP地址的页面,所以同一个页面搜索引擎会重复收录,造成页面的权重不如单个 ...
- MySQL 数据库性能优化之缓存参数优化
在平时被问及最多的问题就是关于 MySQL 数据库性能优化方面的问题,所以最近打算写一个MySQL数据库性能优化方面的系列文章,希望对初中级 MySQL DBA 以及其他对 MySQL 性能优化感兴趣 ...
- [fzu 2271]不改变任意两点最短路至多删的边数
题目链接:http://acm.fzu.edu.cn/problem.php?pid=2271 题目中说每条边的边权都是[1,10]之间的整数,这个条件非常关键!以后一定要好好读题啊…… 做10次循环 ...
- POJ3349 Snowflake Snow Snowflakes (hash
Snowflake Snow Snowflakes Time Limit: 4000MS Memory Limit: 65536K Total Submissions: 48624 Accep ...