MySQL数据库:掌握备份与恢复的艺术,确保数据安全无忧(二)

news2024/11/15 11:50:22

  •  作者简介:我是团团儿,是一名专注于云计算领域的专业创作者,感谢大家的关注
  •  座右铭:   云端筑梦,数据为翼,探索无限可能,引领云计算新纪元
  •  个人主页:团儿.-CSDN博客

目录

​编辑

正文:

Xtrabackup

1. 备份的过程

2. 恢复过程

3. XBK 全备和恢复体验

4. 备份产生的文件介绍

(1) xtrabackup_binlog_info  *****

(2) xtrabackup_checkpoints  *****

二.增量备份

安装xbk

1.清空备份路径

2.修改配置文件

3.模拟数据

4.进行周日的全备

5.模拟周一的数据变化

6.进行周一的增量备份

说明:

7.检查备份的LSN

8.模拟周二数据变化

9.周二的增量

10.周三的数据变化

11.模拟上午10点数据库崩溃

12.恢复思路

13.恢复前的准备

(1) 整理full

(2) 合并inc1到full,并整理备份

(4) 最后一次整理full

14.截取二进制日志

起点:

终点:

查看日志

截取

15.恢复备份数据

16.验证数据


正文:

Xtrabackup

1. 备份的过程

(1) 非InnoDB表,进行短暂的锁表,然后Copy数据文件

(2) 对于InnoDB表,立即出发checkpoint,会立即记录一个LSN,COPY数据文件.

(3) 将备份过程中产生的redo进行截取和保存,并记录此时最新的LSN

2. 恢复过程

模拟了CSR的全过程,在恢复之前,将数据的LSN号和redo LSN号追平

恢复方法就是直接cp回去即可

3. XBK 全备和恢复体验

innobackupex --user=root (--password=123) -S /tmp/mysql.sock --no-timestamp /backup/full

innobackupex --apply-log /backup/full

4. 备份产生的文件介绍

(1) xtrabackup_binlog_info  *****

记录备份时刻的二进制日志信息. 可以作为binlog截取的起点.

(2) xtrabackup_checkpoints  *****

from : 备份中包含的LSN号的起点,全备:0,增量:上次备份的结束位置

to  : ckpt 时的LSN

last-9 : 备份结束时的LSN.下次增量备份的起始位置.


二.增量备份

安装xbk

通过网盘分享的文件:xbk
链接: https://pan.baidu.com/s/16gnS70OmzRsGRLzb1fz60w 提取码: 5i1p

1.清空备份路径

rm -rf /backup/*

2.修改配置文件

vim /etc/my.cnf

添加:

log_bin=/data/binlog/mysql-bin
gtid-mode=on
enforce-gtid-consistency=true

保存并退出

3.模拟数据

create database full charset utf8mb4;

use full;

create table t1 (id int);

insert into t1 values(1),(2),(3);

commit;

4.进行周日的全备

innobackupex --user=root --socket=/tmp/mysql.sock --no-timestamp /backup/full

5.模拟周一的数据变化

create database inc1 charset utf8mb4;

use inc1;

create table t1 (id int);

insert into t1 values(1),(2),(3);

commit;

6.进行周一的增量备份

innobackupex --user=root --no-timestamp --incremental --socket=/tmp/mysql.sock --incremental-basedir=/backup/full /backup/inc1

说明:

--incremental    开启增量备份

--incremental-basedir=/backup/full 基于哪个备份进行增量

/backup/inc1     增量备份的目录

7.检查备份的LSN

cat /backup/full/xtrabackup_checkpoints

cat /backup/inc1/xtrabackup_checkpoints

8.模拟周二数据变化

create database inc2 charset utf8mb4;

use inc2;

create table t1 (id int);

insert into t1 values(1),(2),(3);

commit;

9.周二的增量

innobackupex   --user=root --no-timestamp --incremental --socket=/tmp/mysql.sock --incremental-basedir=/backup/inc1 /backup/inc2

10.周三的数据变化

create database inc3 charset utf8mb4;

use inc3;

create table t1 (id int);

insert into t1 values(1),(2),(3);

commit;

11.模拟上午10点数据库崩溃

pkill mysqld

rm -rf /usr/local/mysql/data/*

12.恢复思路

1. 停业务,挂维护页

2. 查找可用备份并处理备份:full+inc1+inc2

3. binlog: inc2 到 故障时间点的binlog

4. 恢复全备+增量+binlog

5. 验证数据

6. 起业务,撤维护页

13.恢复前的准备

(1) 整理full

innobackupex --apply-log --redo-only  /backup/full

(2) 合并inc1到full,并整理备份

innobackupex --apply-log --redo-only  --incremental-dir=/backup/inc1 /backup/full

(3) 合并inc2到full,并整理备份

innobackupex --apply-log  --incremental-dir=/backup/inc2 /backup/full

(4) 最后一次整理full

innobackupex --apply-log  /backup/full

14.截取二进制日志

起点:

cat /backup/inc2/xtrabackup_binlog_info

终点:

mysqlbinlog /data/mysql-bin.000005 |grep 'SET'

查看日志

mysqlbinlog mysql-bin.000001

截取

mysqlbinlog --skip-gtids --include-gtids='089c733d-60f6-11ef-9a10-000c294d6c98:17-19' /data/binlog/mysql-bin.000001>/tmp/binlog.sql

注:inc2结束为16,所以截取从17开始

15.恢复备份数据

cp -a  /backup/full/* /usr/local/mysql/data/

chown -R mysql:mysql /usr/local/mysql/

/etc/init.d/mysqld start

set sql_log_bin=0;

source /tmp/binlog.sql

16.验证数据

select * from full.t1;

select * from inc1.t1;

select * from inc2.t1;

select * from inc3.t1;


期待您的关注~

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

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

相关文章

springbootKPL比赛网上售票系统

基于springbootvue实现的KPL比赛网上售票系统 (源码L文ppt)4-068 4.2 系统结构设计 架构图是系统的体系结构,体系结构是体系结构体系的重要组成部分。KPL比赛网上售票系统的总体结构设计如图4-2所示。 图4-2 系统总体架构图 4.3数据…

【Java面向对象二】static(二)修饰成员方法的应用场景

文章目录 前言一、static修饰成员方法的应用场景二、使用例子三、工具类没有创建对象的需求,建议将工具类的构造方法进行私有总结 前言 记录学习过程中的工具类的使用。 一、static修饰成员方法的应用场景 1、类方法的常见应用场景 类方法最常见的应用场景是做工…

Java设计模式——工厂方法模式(完整详解,附有代码+案例)

文章目录 5.3 工厂方法模式5.3.1概述5.3.2 结构5.3.3 实现 5.3 工厂方法模式 针对5.2.3中的缺点,使用工厂方法模式就可以完美的解决,完全遵循开闭原则。 5.3.1概述 工厂方法模式:定义一个创建对象的接口(这里的接口指的是工厂&…

01_WebRtc_一对一视频通话

文章目录 通话网页的设计客户端实现Web的API 服务端实现 2024-9-20 很久没有写博客啦,回顾总结这段时间的成果, 写下博客放松下(开始偷懒啦)主要内容:实现网页(html)打开摄像头并显示到页面需要…

泳池软管检测系统源码分享

泳池软管检测检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Computer Vis…

C++: 使用红黑树模拟实现STL中的map和set

目录 1. 红黑树的迭代器和-- 2. 改造红黑树3. set的模拟实现4. map的模拟实现5. RBTree的改造代码 博客主页 : 酷酷学 正文开始 1. 红黑树的迭代器 迭代器的好处是可以方便遍历,是数据结构的底层实现与用户透明 打开C的源码我们可以发现, 其实源码中的底层大概如…

数据结构应试-树和二叉树

1. 2. 结点的度:结点拥有的子树数量称为结点的度 树的度:树内各结点度的最大值,即上图 D 结点的度就是此树的度 叶子:度为 0 的节点称为叶子或终端节点 结点的层次和树的深度 森林:m棵互不相交的树的集合。 3. 为啥…

司南 OpenCompass 九月大语言模型评测榜单启动召集,欢迎新合作厂商申请评测

主要概览 司南 OpenCompass 大语言模型官方自建榜单(9 月榜)评测拟定于 10 月上旬发布,现诚挚邀请新加入的合作方参与评测。本次评测围绕强化能力维度,全面覆盖语言、推理、知识、代码、数学、指令跟随、智能体等七大关键领域&am…

layui时间选择器选择周 日月季度年

<!-- layui框架样式 --><link type"text/css" href"/static/plugins/layui/css/layui.css" rel"stylesheet" /><!-- layui框架js --><script type"text/javascript" src"/static/plugins/layui/layui.js&qu…

【LeetCode】每日一题 2024_9_20 统计特殊整数(数位 DP)

前言 每天和你一起刷 LeetCode 每日一题~ LeetCode 启动&#xff01; 题目&#xff1a;统计特殊整数 代码与解题思路 func countSpecialNumbers(n int) int { // 今天的题目是数位 DP&#xff0c;我不会做&#xff0c;所以现场学习了一下灵神的数位 DP 模版s : strconv.Itoa…

11个推特大V发文推广的数据分析技巧

社交媒体已经成为了现代社会中不可或缺的一部分&#xff0c;而推特作为其中的重要一员&#xff0c;吸引了许多用户。对于那些成千上万的粉丝拥有者&#xff08;也被称为“大V”&#xff09;&#xff0c;他们能够有效地利用推特平台&#xff0c;推广自己的观点和产品。我们将介绍…

让医院更智慧,让决策更容易

依托数字孪生技术&#xff0c;赋能智慧医院&#xff0c;对使用者和决策者带来了众多的优势。数字孪生技术是将物理实体与数字模型相结合&#xff0c;实现实时监测、仿真预测和智能决策的一种先进技术。在智慧医院中应用数字孪生技术&#xff0c;不仅可以提升医疗服务的质量和效…

阿里云容器服务Kubernetes部署新服务

这里部署的是前端项目 1.登录控制台-选择集群 2.选择无状态-命名空间-使用镜像创建 3.填写相关信息 应用基本信息&#xff1a; 容器配置&#xff1a; 高级配置&#xff1a; 创建成功后就可以通过30006端口访问项目了

XML:DOM4j解析XML

XML简介&#xff1a; 什么是XML&#xff1a;XML 是独立于软件和硬件的信息传输工具。 XML 的设计宗旨是传输数据&#xff0c;而不是显示数据。XML 标签没有被预定义。您需要自行定义标签。XML不会做任何事情&#xff0c;XML被设计用来结构化、存储以及传输信息。 XML可以发明…

再次理解UDP协议

一、再谈端口号 在 TCP / IP 协议中&#xff0c;用 "源 IP", "源端口号", "目的 IP", "目的端口号", "协议号" 这样一个五元组来标识一个通信(可以通过 netstat -n 查看) 我们需要端口号到进程的唯一性&#xff0c;所以一个…

工业控制系统等保2.0定级备案经验分享

工业控制系统和传统IT系统有所差异&#xff0c;须单独划分定级对象 工业控制系统定级时将现场采集/执行、现场控制和过程控制等要素应作为一个整体对象定级&#xff0c;各要素不单独定级&#xff1b;生产管理要素可单独定级。对于大型工业控制系统&#xff0c;可以根据系统功能…

Node-red 某一时间范围内满足条件的数据只返回一次

厂子里有个业务需求增加一段逻辑&#xff0c;根据点位数值&#xff0c;判断是否让mes执行之后的逻辑。 网关采集周期5s/次&#xff0c;及数据上报周期5s/次; iot通过网关写入时间为8s左右&#xff1b; 同类设备共用一条规则链&#xff1b; 想当触发条件时修改”完成上传“不…

SimpleAISearch:C# + DuckDuckGo 实现简单的AI搜索

最近AI搜索很火爆&#xff0c;有Perplexity、秘塔AI、MindSearch、Perplexica、memfree、khoj等等。 在使用大语言模型的过程中&#xff0c;或许你也遇到了这种局限&#xff0c;就是无法获取网上最新的信息&#xff0c;导致回答的内容不是基于最新的信息&#xff0c;为了解决这…

[Linux#55][网络协议] 序列化与反序列化 | TcpCalculate为例

目录 1. 理解协议 1.1 结构化数据的传输 序列化与反序列化 代码感知&#xff1a; Request 类 1. 构造函数 2. 序列化函数&#xff1a;Serialize() 3. 反序列化函数&#xff1a;DeSerialize() 补充 4. 成员变量 Response 类 1. 构造函数 2. 序列化函数&#xff1a;…

力扣 中等 2300.咒语和药水的成功对数

文章目录 题目介绍解法 题目介绍 解法 class Solution {public int[] successfulPairs(int[] spells, int[] potions, long success){Arrays.sort(potions);int n spells.length, m potions.length;int[] pairs new int[n];for (int i 0; i < n; i) {int left 0, righ…