【Mysql】Xtrabackup备份恢复(Mysql5.6/5.7/8.0)

目录

一、前言

二、Mysql8.0为例

1、安装Xtraback工具

1)mysql8.0.x版本

2)mysql5.6、5.7版本

2、备份操作

3、恢复操作


一、前言

官网下载地址:Software Downloads - Percona

本测试环境:centos_x86、mysql8.0.39、mysql5.7.x、引擎Innodb

版本区别:

xtrabackup 8.0 支持MySQL8.0版本

xtrabackup 2.4 支持MySQL5.6、5.7版本、MariDB10.1、10.2版本

二、Mysql8.0为例

1、安装Xtraback工具

1)mysql8.0.x版本

bash 复制代码
#安装依赖
yum -y install perl perl-devel libaio libaio-devel perl-Time-HiRes perl-DBD-MySQL rsync perl  perl-Digest-MD5
#获取xtrabackup8.0包
wget -c https://downloads.percona.com/downloads/Percona-XtraBackup-8.0/Percona-XtraBackup-8.0.35-31/binary/redhat/7/x86_64/percona-xtrabackup-80-8.0.35-31.1.el7.x86_64.rpm
#安装
rpm -ivh percona-xtrabackup-83-8.3.0-1.1.el7.x86_64.rpm

如果无外网,本博主提供下载地址如下,包含所依赖rpm包(根据centos7_x86):

链接: 百度网盘 请输入提取码 提取码: 5jkt

2)mysql5.6、5.7版本

bash 复制代码
#安装依赖
yum -y install perl perl-devel libaio libaio-devel perl-Time-HiRes perl-DBD-MySQL rsync perl  perl-Digest-MD5
#获取xtrabackup8.0包
wget -c https://downloads.percona.com/downloads/Percona-XtraBackup-2.4/Percona-XtraBackup-2.4.29/binary/redhat/7/x86_64/percona-xtrabackup-24-2.4.29-1.el7.x86_64.rpm
#安装
rpm -ivh percona-xtrabackup-24-2.4.29-1.el7.x86_64.rpm

如果无外网,本博主提供下载地址如下,包含所依赖rpm包(根据centos7_x86):

链接: 百度网盘 请输入提取码 提取码: 5jkt

2、备份操作

#在备份期间,xtrabackup会运行一个后台进程,用于监视事务日志,并从事务日志复制最新的修改。

bash 复制代码
#创建备份目录
mkdir -p /data/bakup_sql/20240815
#--defaults-file指定my.cnf路径,--user指定用户,--password指定密码,--host指定节点,--port指定端口,--backup指定备份操作,--target-dir指定备份路径
xtrabackup --defaults-file=/usr/local/mysql/my.cnf --user=weiyun --password=weiyun@123 --host=127.0.0.1 --port=3306 --backup --target-dir=/data/bakup_sql/20240815

3、恢复操作

#InnoDB表数据回滚到整个备份结束的点,而不是回滚到xtrabackup刚开始时的点。需停掉mysql进行回滚操作

bash 复制代码
#perpaer操作。备份完的数据存在未提交的事务和已提交未同步到数据文件的事务,需要执行prepare步骤,重做已提交事务,回滚未提交事务,使数据文件保持一致性,target-dir指定备份的目录
xtrabackup --defaults-file=/usr/local/mysql/my.cnf --user=weiyun --password=weiyun@123 --host=127.0.0.1 --port=3306 --prepare --target-dir=/data/bakup_sql/20240815
#回滚数据。datadir指定mysql存储数据目录,必需为空,target-dir为备份数据目录
mv /data/mysql/data /data/mysql/data_bak
xtrabackup --defaults-file=/usr/local/mysql/my.cnf --user=weiyun --password=weiyun@123 --host=127.0.0.1 --port=3306 --copy-back --datadir=/data/mysql/data --target-dir=/data/bakup_sql/20240815

4、海量数据备份优化

bash 复制代码
#对于数据量大,可添加一下参数进行备份
xtrabackup --defaults-file=/usr/local/mysql/my.cnf --user=weiyun --password=weiyun@123 --host=127.0.0.1 --port=3306 --compress-threads=8 --backup --stream=xbstream --parallel=4 | gzip > /data/backup_sql/20240815/mysqlsql.xb.gz

#回滚操作。
#解压至/data/backup_sql/20240815/sql
gzip -d -c /data/backup_sql/20240815/mysqlsql.xb.gz| xbstream -x -v -C /data/backup_sql/20240815/sql
#备份原来mysql数据目录
mv /data/mysql/data /data/mysql/data_bak
#preare操作
xtrabackup --defaults-file=/usr/local/mysql/my.cnf --user=weiyun --password=weiyun@123 --host=127.0.0.1 --port=3306 --prepare --target-dir=/data/bakup_sql/20240815/sql
#开始回滚
xtrabackup --defaults-file=/usr/local/mysql/my.cnf --user=weiyun --password=weiyun@123 --host=127.0.0.1 --port=3306 --copy-back --datadir=/data/mysql/data --target-dir=/data/bakup_sql/20240815/sql
相关推荐
工业甲酰苯胺3 分钟前
分布式系统架构:服务容错
数据库·架构
独行soc1 小时前
#渗透测试#漏洞挖掘#红蓝攻防#护网#sql注入介绍08-基于时间延迟的SQL注入(Time-Based SQL Injection)
数据库·sql·安全·渗透测试·漏洞挖掘
White_Mountain1 小时前
在Ubuntu中配置mysql,并允许外部访问数据库
数据库·mysql·ubuntu
Code apprenticeship1 小时前
怎么利用Redis实现延时队列?
数据库·redis·缓存
百度智能云技术站1 小时前
广告投放系统成本降低 70%+,基于 Redis 容量型数据库 PegaDB 的方案设计和业务实践
数据库·redis·oracle
老王笔记1 小时前
GTID下复制问题和解决
mysql
装不满的克莱因瓶1 小时前
【Redis经典面试题六】Redis的持久化机制是怎样的?
java·数据库·redis·持久化·aof·rdb
Lojarro3 小时前
【Spring】Spring框架之-AOP
java·mysql·spring
梦想平凡3 小时前
PHP 微信棋牌开发全解析:高级教程
android·数据库·oracle
TianyaOAO3 小时前
mysql的事务控制和数据库的备份和恢复
数据库·mysql