Xtrabackup 物理备份

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

全量备份 & 增量备份 对比

增备:
优点:占用磁盘空间小,没有重复数据
缺点:恢复麻烦

全备:
优点:恢复容易,只需一次
缺点:占用磁盘空间,每次全备都有重复数据

posted @ 2020-07-23 15:49  拨云见日z  阅读(261)  评论(0编辑  收藏  举报