Xtrabackup 安装

# 上传文件包
[root@db03 ~]# rz percona-xtrabackup-24-2.4.4-1.el6.x86_64.rpm # 下载epel源
wget -O /etc/yum.repos.d/epel.repo https://mirrors.aliyun.com/repo/epel-6.repo
# 安装依赖
yum -y install perl perl-devel libaio libaio-devel perl-Time-HiRes perl-DBD-MySQL
# 下载Xtrabackup
wget httpss://www.percona.com/downloads/XtraBackup/Percona-XtraBackup-2.4.4/binary/redhat/6/x86_64/percona-xtrabackup-24-2.4.4-1.el6.x86_64.rpm # 安装
[root@db03 ~]# yum localinstall -y percona-xtrabackup-24-2.4.4-1.el6.x86_64.rpm
# 安装好后的命令
[root@db03 ~]# xtrabackup
[root@db03 ~]# innobackupex

Xtrabackup 备份介绍

对于非 innodb 表(比如 myisam)是直接锁表 Copy 数据文件,属于一种温备;

对于 innodb 表(支持事务),不锁表,cp数据页最终以数据文件方式保存下来,并且把 redo 和 undo 一并备走,属于热备方式 。

注意:备份时读取配置文件/etc/my.cnf(如果使用 Xtrabackup 备份,必须要配置 datadir)

Xtrabackup全量备份

准备备份目录

[root@db03 ~]#  mkdir /backup

全量备份

[root@db03 ~]#  innobackupex --user=root --password=123 /backup/full

# 去掉时间戳进行备份
[root@db03 ~]# innobackupex --user=root --password=123 --no-timestamp /backup/full

查看全量备份内容

[root@db03 ~]#  ll /backup/full/
backup-my.cnf
dump
ibdata1
ibdata2
mysql
performance_schema
row
test
xtrabackup_binlog_info # bin-log 信息
xtrabackup_checkpoints # 本次备份的数据的 起始日志序列号(LSN)-结束日志序列号(LSN)
xtrabackup_info # 工具或数据的信息
xtrabackup_logfile # redo-log 信息 [root@db03 full]# cat xtrabackup_checkpoints
backup_type = full-backuped
from_lsn = 0
to_lsn = 8417759

Xtrabackup 全量备份恢复数据

删除所有数据库

# 删库
mysql> drop database dump;
mysql> drop database performance_schema;
mysql> drop database row;
mysql> drop database test;

停止数据库服务

[root@db03 ~]#  systemctl stop mysqld.service

模拟 CSR 的过程

# 将 redo 进行重做,已提交的写到数据文件,未提交的使用 undo 回滚,模拟 CSR 的过程
[root@db03 ~]# innobackupex --user=root --password=123 --apply-log /backup/full

恢复数据

方法一(不推荐)

# 移走原数据目录
[root@db03 mysql]# mv data data.back # 将全备的数据目录迁移回来
[root@db03 mysql]# cp -r /backup/full ./data [root@db03 mysql]# chown -R mysql.mysql data

方法二(推荐)

# 使用 innobackupex 恢复数据
[root@db03 mysql]# innobackupex --copy-back /backup/full/
[root@db03 mysql]# chown -R mysql.mysql data

检验结果

# 启动数据库
[root@db03 data]# systemctl start mysqld
# 查看是否恢复
[root@db03 data]# mysql -uroot -p123
mysql> show databases;

Xtrabackup 增量备份

Xtrabackup 每次基于上一次备份进行增量;

增量备份无法单独恢复,必须基于全备进行恢复;

所有增量必须要按顺序合并到全备当中 。

全量备份

[root@db03 ~]#  innobackupex --user=root --password=123 --no-timestamp /backup/full_$(date +%F)

插入新数据

[root@db03 ~]#  mysql -uroot -p123
mysql> use dump
mysql> insert dump values(10000),(20000),(30000);

第一次增量备份

[root@db01 ~]#  innobackupex --user=root --password=123 --no-timestamp --incremental --incremental-basedir=/backup/full_2020-07-23 /backup/inc1

参数说明:
--incremental:开启增量备份功能
--incremental-basedir:上一次备份的路径 # 验证
[root@db03 ~]# cat /backup/full/xtrabackup_checkpoints
backup_type = full-prepared
from_lsn = 0
to_lsn = 8417759
[root@db03 ~]# cat /backup/inc1/xtrabackup_checkpoints
backup_type = incremental
from_lsn = 8417759
to_lsn = 8419281

插入新数据

[root@db03 ~]#  mysql -uroot -p123
mysql> use dump
mysql> insert dump values(100000),(200000),(300000);

第二次增量备份

[root@db03 ~]#  innobackupex --user=root --password=123 --no-timestamp --incremental --incremental-basedir=/backup/inc1/ /backup/inc2

# 验证
[root@db03 backup]# cat /backup/full_2020-07-23/xtrabackup_checkpoints
backup_type = full-backuped
from_lsn = 0
to_lsn = 1636167 [root@db03 backup]# cat /backup/inc1/xtrabackup_checkpoints
backup_type = incremental
from_lsn = 1636167
to_lsn = 1640828 [root@db03 backup]# cat /backup/inc2/xtrabackup_checkpoints
backup_type = incremental
from_lsn = 1640828
to_lsn = 1645877

Xtrabackup 增量备份恢复数据

将全备执行 Redo

[root@db03 backup]#  innobackupex --apply-log --redo-only /backup/full_2020-07-23

将第一次增备只执行 redo,合并到第一次全备

[root@db03 backup]#  innobackupex --apply-log --redo-only --incremental-dir=/backup/inc1/ /backup/full_2020-07-23

# 验证
[root@db03 backup]# cat /backup/full_2020-07-23/xtrabackup_checkpoints
backup_type = log-applied
from_lsn = 0
to_lsn = 1640828 # 该值本来是inc1的位置点

将最后一次增备执行 redo 和 undo,合并到第一次全备

[root@db03 backup]#  innobackupex --apply-log --incremental-dir=/backup/inc2/ /backup/full_2020-07-23

# 验证
[root@db03 backup]# cat /backup/full_2020-07-23/xtrabackup_checkpoints
backup_type = log-applied
from_lsn = 0
to_lsn = 1645877 # 该值本来是inc2的位置点

将整体数据进行一次 CSR

[root@db03 backup]#  innobackupex --apply-log /backup/full_2020-07-23/

恢复数据

[root@db03 mysql]#  mv data data.bak
[root@db03 mysql]# innobackupex --copy-back /backup/full_2020-07-23/
[root@db03 mysql]# chown -R mysql.mysql ./data
[root@db03 mysql]# systemctl start mysqld

全量备份 & 增量备份 对比

增备:

优点:占用磁盘空间小,没有重复数据

缺点:恢复麻烦

全备:

优点:恢复容易,只需一次

缺点:占用磁盘空间,每次全备都有重复数据

Xtrabackup 物理备份的更多相关文章

  1. XtraBackup物理备份 阿里云的Mysql备份方案

    XtraBackup物理备份 Percona XtraBackup是世界上唯一的开源,免费的MySQL热备份软件,为InnoDB和XtraDB 数据库执行非阻塞备份.使用Percona XtraBac ...

  2. MariaDB xtrabackup物理备份与还原

    xtrabackup物理备份 1.1 安装xtraback 安装依赖: [root@localhost ~]# yum install -y perl-DBD-MySQL perl-DBI perl- ...

  3. Innobackupex(xtrabackup)物理备份

    1. Percona XtraBackup介绍 Percona XtraBackup(简称PXB)是 Percona 公司开发的一个完全开源的用于 MySQL 数据库物理热备的备份工具,在备份过程中不 ...

  4. MySQL数据库之xtrabackup物理备份(一)

    前言:说到数据库备份,我们知道可以用来对数据库进行备份的工具有mysqldump.mydumer.mysqlpump等等,实际工作中,机器上的数据库不大的话,都是用mysqldump工具来备份,这些备 ...

  5. (4.15)mysql备份还原——物理备份之XtraBackup的下载与安装

    关键词:mysql物理备份,XtraBackup,XtraBackup安装,XtraBackup下载 实践链接:https://www.cnblogs.com/gered/p/11147193.htm ...

  6. 使用 xtrabackup 进行MySQL数据库物理备份

    0. xtrabackup的功能 能实现的功能: 非阻塞备份innodb等事务引擎数据库. 备份myisam表会阻塞(需要锁). 支持全备.增量备份.压缩备份. 快速增量备份(xtradb,原理类似于 ...

  7. mysql之使用xtrabackup进行物理备份、恢复、在线克隆从库、在线重做主从

    注:图片来自<深入浅出MySQL 数据库开发 优化与管理维护 第2版> 物理备份和恢复 1.冷备份:停掉mysql再备份,一般很少用,因为很多应用不允许长时间停机,停机备份的可以直接CP数 ...

  8. MySQL · 物理备份 · Percona XtraBackup 备份原理

    http://mysql.taobao.org/monthly/2016/03/07/ 前言 Percona XtraBackup(简称PXB)是 Percona 公司开发的一个用于 MySQL 数据 ...

  9. xtrabackup进行物理备份、恢复、在线克隆从库、在线重做主从

    http://www.lai18.com/content/4733997.html 注:图片来自<深入浅出MySQL 数据库开发 优化与管理维护 第2版> 物理备份和恢复 1.冷备份:停掉 ...

随机推荐

  1. oracle动态采样导致数据库出现大量cursor pin s wait on x等待

    生产库中,突然出现了大量的cursor pin s wait on x等待,第一反应是数据库出现了硬解析,查看最近的DDL语句,没有发现DDL.那么有可能这个sql是第一次进入 在OLTP高并发下产生 ...

  2. BAPI_SALESORDER_CREATEFROMDAT2 条件 定价元素

    用函数 BAPI_SALESORDER_CREATEFROMDAT2创建SO的时候,遇见个问题,就是如图: 会多出来一个类型,搞了半天,发现是一个函数里的一个参数,我没有设置: LOGIC_SWITC ...

  3. 如何用Python中自带的Pandas和NumPy库进行数据清洗

    一.概况 1.数据清洗到底是在清洗些什么? 通常来说,你所获取到的原始数据不能直接用来分析,因为它们会有各种各样的问题,如包含无效信息,列名不规范.格式不一致,存在重复值,缺失值,异常值等..... ...

  4. zabbix-server安装部署配置

    zabbix-server安装部署配置 zabbixLinux安装部署安装脚本 1 一步一步部署 1.1 安装zabbix仓库源 这里安装阿里的zabbix仓库地址 选用zabbix版本3.4 rpm ...

  5. linux opt, usr文件夹说明

    linux下各文件夹介绍: https://www.pathname.com/fhs/pub/fhs-2.3.html /usr:系统级的目录,可以理解为C:/Windows/,/usr/lib理解为 ...

  6. Ice系列--基于IceGrid的部署方案

    前言 前一篇文章介绍了IceGrid的简单应用.这篇文章来介绍一下它的高端玩法-如何将模板,复制组,知名对象应用于部署方案及其作用. 基于模板的部署方案 之前介绍了xml格式的配置文件通过各种描述符如 ...

  7. 使用Swagger2

    一.Swagger2是什么? Swagger 是一个规范和完整的框架,用于生成.描述.调用和可视化 RESTful 风格的 Web 服务. 优点: 及时性 (接口变更后,能够及时准确地通知相关前后端开 ...

  8. ichartjs插件的使用

    项目中可能会用到饼状图.柱状图.环形图等,ichartjs是一个很不错的插件,体量小,只需引入ichart.1.2.1.min.js即可满足基础需求,github下载地址是:https://githu ...

  9. uni-app 获取地址位置

    uni.getLocation 获取当前的地理位置.速度. 在微信小程序中,当用户离开应用后,此接口无法调用:当用户点击"显示在聊天顶部"时,此接口可继续调用 uni.getLoc ...

  10. (13)-Python3之--获取当前时间

    1.导入datetime模块 import datetime 2.获取当前日期和时间 import datetime now_time = datetime.datetime.now() print( ...