xtrabackup全备 增备

news2024/11/19 16:32:37

版本针对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/bash

check_mysql_installed() {
    local num=$(pgrep mysqld |wc -l)
    if [ $num -eq 2 ]; then
        echo "MySQL is already installed."
        return 0
    else
        return 1
    fi
}

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/mysql
    mkdir -p /usr/local/mysql/data
    mkdir -p /usr/local/mysql/log
    groupadd mysql
    useradd -r -g mysql mysql

    chown -R mysql:mysql /usr/local/mysql
    chmod -R 777         /var/lib/mysql/
    chown -R mysql:mysql /usr/local/mysql/data
    chown -R mysql:mysql /usr/local/mysql/log
    chown -R mysql:mysql /var/lib/mysql/mysql.sock
    rm -rf /etc/my.cnf

    cat > /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
EOF

    cd /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/mysqld
    ln -sv /usr/local/mysql/bin/mysql /usr/bin/mysql
    chkconfig --add mysqld
    systemctl start mysqld
}

if check_mysql_installed; then
    exit 0
else
    install_mysql
    if check_mysql_installed; then
        echo "MySQL installed successfully."
    else
        echo "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/时间戳

增备份一个目录

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1088830.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

android 判断是否打开了蓝牙网络共享

最近做项目遇到需要判断手机是否打开了蓝牙网络共享的开关 //调用isBluetoothPanTetheringOn(context) {if (it) {Log.i("TAG","已打开")} else {Log.i("TAG","未打开")context.gotoBleShareSettings()} }/*** 是否打开蓝牙网络共享**…

idea中取消class文件显示所有方法的显示

一 idea中class文件取消显示方法 1.1 取消显示方法 1.显示如下 2.操作如下 3.显示如下

2023年中国固废处理行业研究报告

第一章 行业概况 1.1 定义 固体废物处理是一个日益重要的领域&#xff0c;随着中国城市化进程的加速和工业产值的持续增长&#xff0c;固体废物的产生量也在不断上升。根据《固体废物污染环境防治法》的定义&#xff0c;固体废物包括了人类在生产、生活和其他活动中产生的固态…

基于单目的光流法测速

目录 1.简介 2.代码实现 1.简介 基于单目的光流法是一种常见的计算机视觉技术&#xff0c;用于估计图像序列中物体的运动速度。它通过分析连续帧之间的像素变化来推断物体在图像中的移动情况。 背景&#xff1a; 光流法是计算机视觉领域中最早的运动估计方法之一&#xff0c…

BUUCTF 金三 1

BUUCTF:https://buuoj.cn/challenges 题目描述&#xff1a; 只有一个附件&#xff0c;下载下来有一张GIF图片。 解题思路&#xff1a; 本题一共有2种解法&#xff08;本人找到的&#xff09; 方法一&#xff1a; 1、打开这张GIF图片&#xff0c;观察到不正常闪动&#xff0c;似…

《YOLO医学影像检测》专栏介绍 CSDN独家改进实战

&#x1f4a1;&#x1f4a1;&#x1f4a1;YOLO医学影像检测&#xff1a;http://t.csdnimg.cn/N4zBP ✨✨✨实战医学影像检测项目&#xff0c;通过创新点验证涨点可行性&#xff1b; ✨✨✨入门医学影像检测到创新&#xff0c;不断打怪进阶&#xff1b; 1.血细胞检测介绍 数据…

数据结构 - 2(顺序表10000字详解)

一&#xff1a;List 1.1 什么是List 在集合框架中&#xff0c;List是一个接口&#xff0c;继承自Collection。 Collection也是一个接口&#xff0c;该接口中规范了后序容器中常用的一些方法&#xff0c;具体如下所示&#xff1a; Iterable也是一个接口&#xff0c;Iterabl…

security+JWT

securityJWT 添加依赖准备工作sqlUserInfoUserMapperUserService、UserServiceImpl 创建JwtUtils工具类&#xff0c;做token的生成和校验进入Security创建AccountDetailsServiceImpl&#xff0c;并且实现UserDetailsService编写登录操作 创建拦截器JWTAuthenticationFilter继承…

mac电影特效合成软件nuke15 完美激活版下载

Nuke 15是一款由英国The Foundry公司开发的专业的合成软件&#xff0c;被广泛用于电影、电视和广告制作中的后期合成和特效制作。 Mac软件下载&#xff1a;nuke15 完美激活版下载 Win软件下载&#xff1a;NUKE 13 中文激活版 Nuke 15拥有强大的功能和灵活性&#xff0c;可以帮助…

TartanVO: A Generalizable Learning-based VO 服务器复现(rtx3090 py3)

源码地址 代码地址&#xff1a;https://github.com/castacks/tartanvo/tree/python3 配环境 git clone https://github.com/castacks/tartanvo.git -b python3创建conda环境&#xff1a; conda create -n tartanvo python3.8安装pytorch conda install pytorch1.10.1 torc…

路由router

什么是路由? 一个路由就是一组映射关系&#xff08;key - value&#xff09;key 为路径&#xff0c;value 可能是 function 或 component 2、安装\引入\基础使用 只有vue-router3&#xff0c;才能应用于vue2&#xff1b;vue-router4可以应用于vue3中 这里我们安装vue-router3…

elementUI el-table+树形结构子节点选中后没有打勾?(element版本问题 已解决)

问题 1.不勾选父级CB111&#xff0c;直接去勾选子级&#xff08;ST2001…&#xff09;&#xff0c;子级选中后没有打勾显示 排查 一直以为是这个树形结构和表格不兼容产生的问题&#xff0c;到后来看官方demo都是可以勾选的&#xff0c;最后排查到了版本问题&#xff0c; 项…

电动滑板车UL2272认证测试项目和标准

平衡车ul2272认证标准于2016年2月正式公布&#xff0c;美国消费品安全协会(cpsc)宣布&#xff0c;所有平衡车(包括扭扭车)的制造商、进口商、经销商&#xff0c;其在美国本土生产、进口、销售的平衡车必须符合新的安全标准&#xff0c;包括ul2272平衡车电路系统认证标准。另外&…

flutter开发入门,windows环境安装,耗时一天解决各种bug,终于成功

首先说明要安装的环境&#xff1a;java8必须&#xff0c;android studio&#xff0c;chrome是开发安卓和web是必须的 java8的下载地址&#xff1a;https://www.java.com/en/download/、 java8蓝奏云下载地址&#xff1a;jre-8u381-windows-x64.exe - 蓝奏云 flutter国内环境…

lvgl 界面管理器

lv_scr_mgr lvgl 界面管理器 适配 lvgl 8.3 降低界面之间的耦合使用较小的内存&#xff0c;界面切换后会自动释放内存内存泄漏检测 使用方法 在lv_scr_mgr_port.h 中创建一个枚举&#xff0c;用于界面ID为每个界面创建一个页面管理器句柄将界面句柄添加到 lv_scr_mgr_por…

C++11新特性(lambda,可变参数模板,包装器,bind)

lambda表达式是什么&#xff1f;包装器又是什么&#xff1f;有什么作用&#xff1f;莫急&#xff0c;此篇文章将详细带你探讨它们的作用。很多同学在学习时害怕这些东西&#xff0c;其实都是方便使用的工具&#xff0c;很多情况下我们学这些新的东西觉得麻烦&#xff0c;累赘&a…

自学嵌入式多久才可以达到找工作的水平

自学嵌入式多久才可以达到找工作的水平 时间以及达到嵌入式工作水平所需的具体努力因人而异。但一般而言&#xff0c;自学嵌入式系统开发需要时间和毅力。以下是一些关键因素&#xff0c;影响着您能够在多久内达到找工作的水平&#xff1a;最近很多小伙伴找我&#xff0c;说想要…

YOLOv4 论文总结

贡献&#xff1a; 1.有效且强大的模型&#xff0c;常规GPU&#xff08;1080ti or 2080ti&#xff09;可得到实时、高质量的检测结果。 2.在训练中&#xff0c;验证 Bag-of-Freebies 和 Bag-of-Specials 方法 3.提出了两种数据增强手段&#xff0c;马赛克和自对抗训练&#x…

LeetCode【74】搜索二维矩阵

题目&#xff1a; 代码&#xff1a; public static boolean searchMatrix(int[][] matrix, int target) {int rows matrix.length;int columns matrix[0].length;// 先找到行&#xff0c;行为当前行第一列<target&#xff0c;当前行1行&#xff0c;第一列>targetfor…

详细教程:Postman 怎么调试 WebSocket

WebSocket 是一个支持双向通信的网络协议&#xff0c;它在实时性和效率方面具有很大的优势。Postman 是一个流行的 API 开发工具&#xff0c;它提供了许多功能来测试和调试 RESTful API 接口&#xff0c;最新的版本也支持 WebSocket 接口的调试。想要学习更多关于 Postman 的知…