xtrabackup全备 增备

2023-10-16 12:30
文章标签 xtrabackup 全备 增备

本文主要是介绍xtrabackup全备 增备,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

版本针对mysql8.0版本

官方下载地址 https://www.percona.com/downloads

自行选择下载方式

yum安装方式 

 1、下载上传服务器 安装软件 

[root@master mysql]# ll percona-xtrabackup-80-8.0.33-28.1.el7.x86_64.rpm
-rw-r--r--. 1 root root 44541856 Oct 10 13:25 percona-xtrabackup-80-8.0.33-28.1.el7.x86_64.rpm
[root@master mysql]# yum -y install percona-xtrabackup-80-8.0.33-28.1.el7.x86_64.rpm
[root@master ~]# xtrabackup -version
2023-10-11T15:13:58.035145+08:00 0 [Note] [MY-011825] [Xtrabackup] recognized server arguments: --datadir=/usr/local/mysql/data
xtrabackup version 8.0.33-28 based on MySQL server 8.0.33 Linux (x86_64) (revision id: b3a3c3dd)
[root@master ~]#

自行安装mysql 作为测试数据库使用

或者使用此脚本

注意 需要修改

数据库下载地址

https://downloads.mysql.com/archives/get/p/14/file/mysql-cluster-8.0.33-linux-glibc2.12-x86_64.tar.xz

tar -xvf /opt/src/mysql-8.0.33-linux-glibc2.12-x86_64.tar.xz -C /usr/local/

要下载mysql软件包 上传到服务器的指定目录

[root@master ~]# cat install_mysql.sh
#!/bin/bashcheck_mysql_installed() {local num=$(pgrep mysqld |wc -l)if [ $num -eq 2 ]; thenecho "MySQL is already installed."return 0elsereturn 1fi
}install_mysql() {tar -xvf /opt/src/mysql-8.0.33-linux-glibc2.12-x86_64.tar.xz -C /usr/local/cd /usr/local && mv mysql-8.0.33-linux-glibc2.12-x86_64/ mysql/mkdir -p /var/lib/mysqlmkdir -p /usr/local/mysql/datamkdir -p /usr/local/mysql/loggroupadd mysqluseradd -r -g mysql mysqlchown -R mysql:mysql /usr/local/mysqlchmod -R 777         /var/lib/mysql/chown -R mysql:mysql /usr/local/mysql/datachown -R mysql:mysql /usr/local/mysql/logchown -R mysql:mysql /var/lib/mysql/mysql.sockrm -rf /etc/my.cnfcat > /etc/my.cnf <<EOF
[mysql]
default-character-set=utf8[mysqld]
lower-case-table-names=1
port=3306
socket=/var/lib/mysql/mysql.sock
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
max_connections=100000
wait_timeout=3153600
character-set-server=utf8
default-storage-engine=InnoDB
max_allowed_packet=200M
pid-file=/usr/local/mysql/mysqld.pid
log-error=/usr/local/mysql/log/mysqld.log
[client]
port=3306
socket=/var/lib/mysql/mysql.sock
EOFcd /usr/local/mysql./bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data/cp ./support-files/mysql.server /etc/rc.d/init.d/mysqldln -sv /usr/local/mysql/bin/mysql /usr/bin/mysqlchkconfig --add mysqldsystemctl start mysqld
}if check_mysql_installed; thenexit 0
elseinstall_mysqlif check_mysql_installed; thenecho "MySQL installed successfully."elseecho "Failed to install MySQL."fi
fi

数据库默认密码查看 cat tailf /usr/local/mysql/log/mysqld.log

1、mysql -uroot -p

输入初始密码

进入数据库先修改密码,不修改密码不能使用

alter user "root"@"localhost" identified by '123456';

表示用户"root"可以从任何主机连接到MySQL数据库,方便我们使用外部工具

update mysql.user set host="%" where user="root";

创建一个给备份时候用的数据库

create user "back"@"%" identified by "123456";

#这个注意授权的权限我开启的全部,因为是测试环境为了方便,如果是给公司生产上使用,建议还是规范使用授权

grant all on *.* to "back"@"%";

FLUSH PRIVILEGES;

创建数据库就自行创建,使用工具点点就创建了

=========================================================================

在开始全量备份前 准备一些测试数据库方便验证

开始全量备份

# 全量备份数据库 
mkdir -p /backup/full
xtrabackup --backup --target-dir=/backup/full --user=back --password=123456 --host=192.168.25.129 --port=3306# 备份数据目录
mv /usr/local/mysql/data/ /usr/local/mysql/databak  # 重命名表示已备份数据目录# 停止 MySQL 服务器
systemctl stop mysql# 创建新的数据目录
mkdir /usr/local/mysql/data/  # 创建新的数据目录以准备恢复
chown -R mysql:mysql /usr/local/mysql/data  # 设置目录所有者为MySQL用户# 准备备份数据
xtrabackup --prepare --apply-log-only --target-dir=/backup/full/
xtrabackup --prepare --target-dir=/backup/full/# 复制备份数据到新的数据目录
xtrabackup --copy-back --target-dir=/backup/full/# 设置新的数据目录的权限
chown -R mysql:mysql /usr/local/mysql/data/*# 启动 MySQL 服务器
systemctl start mysql

 在执行第一步全量备份后把初始数据库的data目录给更改后创建新的空data目录,就是等于把data  给清空

在执行后面的恢复数据库登录数据库查看还是正常的数据

 

=========================================================================

上面是全量的备份、恢复

增量数据备份 恢复就是在全量备份的基础上继续备份,备份的数据是后续生产的数据

比如 早上9点全量备份后   增量备份是在下午6点,那么这一次的增量数据就是9点到6点的数据

上面已经做过全量备份全量备份的目录是在 /backup/full 里面

开始增量备份前需要数据库在创建一些测试数据经行对比

自己自行创建创建完成后执行

1、创建测试数据  执行下面语句

xtrabackup --backup --target-dir=/backup/inc1 --user=back --password=123456 --host=192.168.25.129 --port=3306 --incremental-basedir=/backup/full

注意  上下这俩个都是增量备份数据的恢复  一个是inc1  一个是inc2

inc1数据目录是根据/backup/full 后开始备份

inc2数据目录是根据/backup/inc1后开始备份

inc1备份数据  也要和inc2数据有些区别

这个最后会解释

2、创建不一样的测试数据  执行下面语句

xtrabackup --backup --target-dir=/backup/inc2 --user=back --password=123456 --host=192.168.25.129 --port=3306 --incremental-basedir=/backup/inc1

 重复操作删除数据库的data目录

3、删除data mysql数据库目录   
mv /usr/local/mysql/data /usr/local/mysql/data5 4、创建新的 授权mysql
mkdir /usr/local/mysql/data
chown -R mysql:mysql /usr/local/mysql/data/# 在备份目录执行以下命令以准备全量备份数据
xtrabackup --prepare --apply-log-only --target-dir=/backup/full/# 接下来,添加第一个增量备份
xtrabackup --prepare --apply-log-only --target-dir=/backup/full/ --incremental-dir=/backup/inc1/# 如果有第二个增量备份,也可以添加它
xtrabackup --prepare --apply-log-only --target-dir=/backup/full/ --incremental-dir=/backup/inc2/# 最后的准备,这会完成整个数据库恢复
xtrabackup --prepare --target-dir=/backup/full/# 将数据拷贝回MySQL数据目录
xtrabackup --copy-back --target-dir=/backup/full/# 修改MySQL数据目录的所有者,以确保MySQL可以访问
chown -R mysql:mysql /usr/local/mysql/data/*# 重新启动MySQL服务以加载恢复后的数据
systemctl restart mysqld

查看是否恢复了全部数据

上面是完整的使用操作,有问题留言

注意: 每次备份在备份数据库的目录下都有xtrabackup_checkpoints文件 

这是我的三个

cat /backup/full/xtrabackup_checkpoints[root@master ~]# cat /backup/full/xtrabackup_checkpoints
backup_type = full-prepared
from_lsn = 0
to_lsn = 19679426
last_lsn = 19679426
flushed_lsn = 19679426
redo_memory = 0
redo_frames = 0[root@master ~]# cat /backup/inc1/xtrabackup_checkpoints
backup_type = incremental
from_lsn = 19639598
to_lsn = 19653067
last_lsn = 19653067
flushed_lsn = 19653067
redo_memory = 0
redo_frames = 0[root@master ~]# cat /backup/inc2/xtrabackup_checkpoints
backup_type = incremental
from_lsn = 19653067
to_lsn = 19679426
last_lsn = 19679426
flushed_lsn = 19679426
redo_memory = 0
redo_frames = 0


[root@master ~]#

备份的 开始是 LSN(from_lsn )

结束是 LSN(to_lsn),

from_lsn 应该等于上一步备份的 to_lsn

要保证 inc1的to_lsn是19653067    inc2的from_lsn是 19653067

所以每次增量都是从上次一的尾开始到第一次的头结束

不然会有这个报错

2023-10-11T14:20:41.209319+08:00 0 [ERROR] [MY-011825] [Xtrabackup] This incremental backup seems not to be proper for the target.
2023-10-11T14:20:41.209325+08:00 0 [ERROR] [MY-011825] [Xtrabackup] Check 'to_lsn' of the target and 'from_lsn' of the incremental.

生产环境使用脚本 比如 每8天晚上11点经行一次全量备份   每个3天的晚上11一次增备份

主备份可以每次生成一个时间戳文件,检测/back下面的文件删除30天之前文件,增倍目录也是一样的操作

/back/时间戳

增备份一个目录

 

 

这篇关于xtrabackup全备 增备的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/220180

相关文章

【mysql】mysql之物理备份Xtrabackup

本站以分享各种运维经验和运维所需要的技能为主 《python零基础入门》:python零基础入门学习 《python运维脚本》: python运维脚本实践 《shell》:shell学习 《terraform》持续更新中:terraform_Aws学习零基础入门到最佳实战 《k8》从问题中去学习k8s 《docker学习》暂未更新 《ceph学习》ceph日常问题解决分享 《日志收集》ELK

centos7 xtrabackup mysql(8)压缩 全量备份 还原(4)

centos7 xtrabackup mysql(8)压缩 全量备份 还原(4) 查看版本: xtrabackup --version qpress --help 主机端 mysql -u root -p 1234aA~1 use company_pro; insert into employee(name) value (‘20240823_1401’); sudo mkdir -p

centos7 xtrabackup mysql 基本测试(2)---虚拟机环境 设置

centos7 xtrabackup mysql 基本测试(2)—虚拟机环境 设置 参考 虚拟机 安装 centos7 Server 不带桌面 https://blog.csdn.net/wowocpp/article/details/139465713 1. 查看ip ip addr sudo yum install wget -y sudo yum install lrzsz -y

mysql centos xtrabackup

查看版本: xtrabackup --version 检查是否安装成功: mysql 小例子 https://blog.csdn.net/wowocpp/article/details/139501625 《Centos7——实战-完全备份和增量备份》 https://blog.csdn.net/weixin_45842014/article/details/109049759 CentoS

MySQL 使用 XtraBackup 进行数据热备份指导 [全量+增量]

背景 最近一直涉猎 MySQL 数据库的操作、集群部署知识 注意到,为保证数据安全,掌握数据备份是极为重要的 相比小型服务的冷备份而言 在此推荐并整理,更受推崇的 XtraBackup 下的热备份技巧 ☞ 概念了解 [XtraBackup] XtraBackup 是一种物理备份工具,通过协议连接到 MySQL 服务端,然后读取并复制底层的文件,完成物理备份 优势 XtraBacku

【5】MySQL数据库备份-XtraBackup - 全量备份

MySQL数据库备份-XtraBackup-全量备份 前言环境版本 安装部署下载RPM 包二进制包 安装卸载 场景分析全量备份 | 恢复备份恢复综合 增量备份 | 恢复部分备份 | 恢复 前言 关于数据库备份的一些常见术语、工具等,可见《MySQL数据库-备份》章节,当前不再重复概述。本篇主要对 XtraBackup 工具的使用做下详细讲解。 首先,说下所使用的环境、版本。

手动构建percona-xtrabackup Docker镜像,并实现mysql数据备份

由于最近项目比较多,并且都需要自己部署运维Mysql,为了保证mysql数据的安全,那么数据备份就必不可少了。之前做mysql数据备份的时候,都是使用的xtrabackup,所以这次也不例外,由于需要备份的mysql服务器较多,每台都安装一遍xtrabackup的话,重复工作量就太大了,这时候,当然就想着将xtrabackup容器化,需要使用的地方,只需要拉取一下镜像,启动一下容器,感觉一下子就简

mysql实战——xtrabackup全量备份/增量备份及恢复

一、测试前准备 mysql数据库 端口3306数据文件目录 /data/mysql/3306/data 安装目录/usr/lcoal/mysql配置文件/etc/my.cnf 创建数据库 testXtra  创建备份目录 备份目录/data/backup/备份恢复数据文件目录/data/mysql/3307/data备份恢复配置文件/etc/my_3307.cnf  二、开始测试

xtrabackup 详解(已纠正)

xtrabackup是Percona公司CTO Vadim参与开发的一款基于InnoDB的在线热备工具,具有开源,免费,支持在线热备,备份恢复速度快,占用磁盘空间小等特点,并且支持不同情况下的多种备份形式。xtrabackup的官方下载地址为http://www.percona.com/software/percona-xtrabackup。 xtrabackup包含两个主要的工具,即x

centos7 xtrabackup安装配置

#安装 yum install https://repo.percona.com/yum/percona-release-latest.noarch.rpm yum install percona-xtrabackup-24 #--------------------------------------------------------------------------------------