【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
相关推荐
曹牧14 小时前
Oracle EXPLAIN PLAN
数据库·oracle
BD_Marathon14 小时前
SQL学习指南——视图
数据库·sql
活宝小娜14 小时前
mysql详细安装教程
数据库·mysql·adb
贤时间14 小时前
codex 助力oracle ebs 开发
数据库·oracle
秉承初心14 小时前
PostgreSQL 数据性能瓶颈突破实战
数据库·postgresql·oracle
Database_Cool_14 小时前
什么是数据仓库物化视图?AnalyticDB MySQL 实时物化视图能力解析
人工智能·mysql·阿里云
Database_Cool_15 小时前
即席查询(Ad-Hoc)数据库选型:AnalyticDB MySQL 秒级 Ad-Hoc 分析方案
数据库·mysql
一杯奶茶¥15 小时前
水果销售网站 CRM客户信息管理系统 超市管理系 酒店管理系统 健身房管理系统 在线音乐网站 校园招聘系统
java·vue.js·spring boot·mysql·spring·java项目
Nontee15 小时前
新手数据库进阶:一条UPDATE语句的“奇妙漂流”
数据库