物理备份xtrabackup
物理备份: 直接复制数据库文件,适用于大型数据库环境,不受存储引擎的限制,但不能恢复到不同的MySQL版本。
1.完全备份-----完整备份:
每次都将所有数据(不管自第一次备份以来有没有修改过),进行一次完整的复制,备份后会清除文件的存档属性,方便日后增量备份或者差异备份进行版本比较。
特点:占用空间大,备份速度慢,但恢复时一次恢复到位,恢复速度快。
2.增量备份: 每次备份上一次备份到现在产生的新数据
在第一次完整备份之后,第二次开始每次都将添加了存档属性的文件进行备份,并且在备份之后再把这些存档属性清除。为什么要清除存档属性呢?这就是为了下一次备份的时候判断是否有文件变化,因为用户在每次备份以后修改这些被清除存档属性的文件,存档属性就会自动加上,相当于用户告诉系统,这些文件有变化,你下一次就备份这些文件,其他没有存档属性的就不需要备份,这就是增量备份的工作机制。
特点:因每次仅备份自上一次备份(注意是上一次,不是第一次)以来有变化的文件,所 以备份体积小,备份速度快,但是恢复的时候,需要按备份时间顺序,逐个备份版本进行恢 复,恢复时间长。
3.差异备份:只备份跟完整备份不一样的
在第一次完整备份之后,第二次开始每次都将所有文件与第一次完整备份的文件做比较,把自第一次完整备份以来所有修改过的文件进行备份,且以后每次备份都是和第一次完整备份进行比较(注意是第一次,不是上一次),备份自第一次完整备份以来所有的修改过的文件。因此,差异备份在备份完毕之后不需要清除文件的存档属性,因为这些文件和下一次备份没有什么关系,它仅仅和第一次完整备份的数据进行比较(第一次完整备份之后是清除存档属性的)。
(相当于第一次机器人把地板打扫干净了,你踩过,就会有脚印,机器人就把脚印记录下 来,但不打扫,下次你又有踩脏的,机器人就把你这几次所有踩脏的地方都记录下来,始终 不打扫,每次都这样。机器人每次记录的内容就相当于差异备份的内容)
特点:占用空间比增量备份大,比完整备份小,恢复时仅需要恢复第一个完整版本和最后一次的差异版本,恢复速度介于完整备份和增量备份之间。
简单的讲,完整备份就是不管三七二十一,每次都把指定的备份目录完整的复制一遍,不管目录下的文件有没有变化;增量备份就是每次将之前(第一次、第二次、直到前一次)做过备份之后有变化的文件进行备份;差异备份就是每次都将第一次完整备份以来有变化的文件进行备份。
热备份:
数据库启动同时给客户端提供服务的情况下
冷备份:
数据库要关掉或者不能给客户端提供服务
1.安装xtrabackup
官网: www.percona.com
安装xtrabackup
# wget http://www.percona.com/downloads/percona-release/redhat/0.1-4/percona-release-0.1-4.noarch.rpm
# rpm -ivh percona-release-0.1-4.noarch.rpm
[root@mysql-server yum.repos.d]# vim percona-release.repo
修改如下内容:将原来的1改为0
[root@mysql-server yum.repos.d]# yum -y install percona-xtrabackup-24.x86_64
我做实验时 使用的是提前下载好的包
将下载到本地的包 导到服务器上
# rz
解压
#tar xzf xtrabackup.tar.gz -C /opt#cd /opt
# cd xtrabackup/
安装所有rpm包
yum localinstall *下载好以后 如果能在命令行 输入innob直接tab出来 innobackupex 则说明下载安装成功
完全备份流程
1.1首先创建一个备份目录
[root@localhost ~]# mkdir /root/xtrabackup/full -p
1.2备份数据
[root@localhost ~]# innobackupex --user=root --password='Qianfeng@123' /root/xtrabackup/full/user是登录MySQL的系统用户
password是登录MySQL的系统用户密码
语法:innobackupex --user=root --password='密码' /存放备份的路径
1.3查看备份数据是否成功
[root@localhost ~]# cd xtrabackup/full/
[root@localhost full]# ls
2023-10-07_18-47-56
完全备份恢复流程
1.4停止数据库
# systemctl stop mysqld 提前将防火墙与selinux关闭
1.5清理环境
# rm -rf /var/lib/mysql/*
1.6重演回滚
# innobackupex --apply-log --redo-only /root/xtrabackup/full/2023-10-07_18-47-56/
语法: innobackupex --apply-log --redo-only /存放完全备份数据的目录
恢复之前需要确认配置文件内有数据库目录指定,不然xtrabackup不知道恢复到哪里
# cat /etc/my.cnf
[mysqld]
datadir=/var/lib/mysql
1.7数据恢复
# innobackupex --copy-back /存放完全备份的地址
语法: innobackupex --copy-back /存放完全备份地址
1.8更改权限
数据恢复以后会在/var/lib/mysql 下生成新的文件 这些文件在运行启动MySQL服务时 会用到,因此这些文件的属组以及属主都得是MySQL
# chown -R mysql.mysql *
1.9启动服务
# systemctl start mysqld
增量备份流程
实验代替语言
2.1首先一个数据库里面有 表数据
mysql> select * from student;
+------+------+------+
| id | name | time |
+------+------+------+
| 1 | aaa | 1 |
+------+------+------+
1 row in set (0.00 sec)
2.2完全备份它
首先创建存放完全备份目录
# mkdir /root/xtrabackup/full/ -p
存放增量备份的目录
# mkdir /root/xtrabackup/zlbf/ -p
完全备份
# innobackupex --user=root --password='Qianfeng@123' /root/xtrabackup/full/
2.3到数据库插入新的数据
mysql> use school;mysql> insert into student values(2,'bbb',2);
2.4备份新的数据
# innobackupex --user=root --password='Qianfeng@123' --incremental /root/xtrabackup/zlbf/ --incremental-basedir /root/xtrabackup/full/2023-10-07_19-23-32/
2.5停止服务,清理环境
# systemctl stop mysqld
# rm -rf /var/lib/mysql/*
2.6回滚
首先回滚最先开始备份的完全备份好的数据
# innobackupex --apply-log --redo-only /root/xtrabackup/full/2023-10-07_19-23-32/接着回滚增量备份的数据,而增量数据实在完全备份以后新增的数据,因此
# innobackupex --apply-log --redo-only /root/xtrabackup/full/2023-10-07_19-23-32/ --incremental-dir /root/xtrabackup/zlbf/2023-10-07_19-31-01/
回滚非完全备份的数据 语法: innobackupex --apply-log --redo-only /完全备份的数据路径
--incremental-dir /这次要回滚的备份数据
也就是前面是 回滚完全备份的数据 将后面追加的备份数据加到完全备份数据里
2.7恢复
由于前面回滚的时候将全部的备份数据都回滚到完全备份那里,因此恢复的时候只需要恢复完全备份的数据即可
# innobackupex --copy-back /root/xtrabackup/full/2023-10-07_19-23-32/
2.8设置权限
# chown -R mysql.mysql /var/lib/mysql/*
2.9启动服务即可
# systemctl start mysqld
差量备份
以周一周二 周三为例
3.1先完全备份周一,增量备份周二
准备数据库
mysql> select * from student;
+------+------+------+
| id | name | time |
+------+------+------+
| 1 | aaa | 1 |
+------+------+------+
1 row in set (0.00 sec)完全备份周一
# innobackupex --user=root --password='Qianfeng@123' /root/xtrabackup/full/插入数据周二
mysql> select * from student;
+------+------+------+
| id | name | time |
+------+------+------+
| 1 | aaa | 1 |
| 2 | bbb | 2 |
+------+------+------+增量备份周二
# innobackupex --user=root --password='Qianfeng@123' --incremental /root/xtrabackup/zlbf/ --incremental-basedir /root/xtrabackup/full/2023-10-07_20-09-51/
3.2添加数据周三,然后差异备份
ysql> select * from student;
+------+------+------+
| id | name | time |
+------+------+------+
| 1 | aaa | 1 |
| 2 | bbb | 2 |
| 3 | bbb | 3 |
+------+------+------+
3 rows in set (0.01 sec)差异备份,差异备份是基于上一次完全备份之后的 因此
# innobackupex --user=root --password='Qianfeng@123' --incremental /root/xtrabackup/xybf/ --incremental-basedir /root/xtrabackup/full/2023-10-07_20-09-51/删除数据库school
mysql> drop database school;
Query OK, 1 row affected (0.01 sec)mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sys |
+--------------------+
4 rows in set (0.00 sec)
3.3停止服务,清理环境
# systemctl stop mysqld
# cd /var/lib/mysql
# rm -rf *
3.4回滚
回滚周一
# innobackupex --apply-log --redo-onpy /root/xtrabackup/full/2023-10-07_20-09-51/回滚周三,将其回滚到周一中,因为周三是差异备份,他是基于上一次完全备份以后的,因此周三 含有周二 周三的内容
# innobackupex --apply-log --redo-onpy /root/xtrabackup/full/2023-10-07_20-09-51/ --incremental-dir /root/xtrabackup/xybf/2023-10-07_20-21-20/
3.5恢复
由于数据都回滚到周一的完全备份当中,因此只需要恢复周一内容即可
# innobackupex --copy-back root/xtrabackup/full/2023-10-07_20-09-51/
3.6设置权限
# chown -R mysql.mysql /var/lib/mysql/*
3.7启动服务:
# systemctl start mysqld
相关文章:

物理备份xtrabackup
物理备份: 直接复制数据库文件,适用于大型数据库环境,不受存储引擎的限制,但不能恢复到不同的MySQL版本。 1.完全备份-----完整备份: 每次都将所有数据(不管自第一次备份以来有没有修改过)&am…...

1.springcloudalibaba nacos2.2.3部署
前言 nacos是springcloudalibaba体系的注册中心,演示如何搭建最新稳定版本的linux搭建。 前置条件,安装好jdk1.8 一、二进制压缩包下载 1.1 下载压缩包 nacos下载 点击下载下载后得到二进制包如下 nacos-2.2.3.tar.gz二、安装步骤 2.1.解压二进制…...

Linux 查看是否安装memcached
telnet 127.0.0.1 11211这样的命令连接上memcache,然后直接输入stats就可以得到memcache服务器的版本 安装memcached : sudo apt-get install memcached...

设计模式14、命令模式 Command
解释说明:命令模式(Command Pattern)是一种数据驱动的设计模式,它属于行为型模式。请求以命令的形式包裹在对象中,并传递给调用对象。调用对象寻找可以处理该命令的合适对象,并把该命令传给相应的对象&…...

【Go】excelize库实现excel导入导出封装(一),自定义导出样式、隔行背景色、自适应行高、动态导出指定列、动态更改表头
前言 最近在学go操作excel,毕竟在web开发里,操作excel是非常非常常见的。这里我选择用 excelize 库来实现操作excel。 为了方便和通用,我们需要把导入导出进行封装,这样以后就可以很方便的拿来用,或者进行扩展。 我参…...

【开发篇】二十、SpringBoot整合RocketMQ
文章目录 1、整合2、消息的生产3、消费4、发送异步消息5、补充:安装RocketMQ 1、整合 首先导入起步依赖,RocketMQ的starter不是Spring维护的,这一点从starter的命名可以看出来(不是spring-boot-starter-xxx,而是xxx-s…...

OpenCV实现求解单目相机位姿
单目相机通过对极约束来求解相机运动的位姿。参考了ORBSLAM中单目实现的代码,这里用opencv来实现最简单的位姿估计. mLeftImg cv::imread(lImg, cv::IMREAD_GRAYSCALE); mRightImg cv::imread(rImg, cv::IMREAD_GRAYSCALE); cv::Ptr<ORB> OrbLeftExtractor …...

深入解析PostgreSQL:命令和语法详解及使用指南
文章目录 摘要引言基本操作安装与配置连接和退出 数据库操作创建数据库删除数据库切换数据库 表操作创建表删除表插入数据查询数据更新数据删除数据 索引和约束创建索引创建约束 用户管理创建用户授权用户修改用户密码 备份和恢复备份数据库恢复数据库 高级特性结语参考文献 摘…...
Elasticsearch数据搜索原理
Elasticsearch 是一个开源的、基于 Lucene 的分布式搜索和分析引擎,设计用于云计算环境中,能够实现实时的、可扩展的搜索、分析和探索全文和结构化数据。它具有高度的可扩展性,可以在短时间内搜索和分析大量数据。 Elasticsearch 不仅仅是一个…...

vue模版语法-{{}}/v-text/v-html/v-once
一、{{}}双括号:用于文本渲染 1、 {{变量名}}:data中返回对象的变量名 2、{{js表达式}}:可以直接进行js表达式处理 3、注意:双大括号中不要写等式书写 二、v-text 指令,用于文本渲染 1、为了解决双大括号渲染数据出现闪烁问题 三、v-cloak …...
前端埋点上传
没事看看: 从用户行为到数据:数据采集全景解析 | 人人都是产品经理 搭建前端监控,采集用户行为的 N 种姿势-前端监控设备 创业公司做数据分析(三)用户行为数据采集系统-CSDN博客...
第11章 Redis(一)
11.1 谈谈你对Redis的理解 难度:★★★ 重点:★★ 白话解析 对Redis的理解无非从三个方面去说一说:背景,是什么,特性。 背景:数据直接存磁盘太慢了,虽然MySQL用到了BufferPool等缓存,但是为了保证数据不丢失,MySQL采用的RedoLog依然要直接写磁盘。所以,数据的存储就…...
freertos信号量之二值信号量
freertos信号量之二值信号量 简介例程 简介 FreeRTOS的二值信号量(Binary Semaphore)是用于实现进程间同步和临界资源保护的重要工具。以下是一些二值信号量的常用函数及其说明: 1)xSemaphoreCreateBinary() 创建一个二值信号量…...

notepad++ 如何去除换行
选中下方的“扩展” “查找目标”输入:\r\n,替换为:空白 最后全部替换。...

PPT NO.2 插入透明校徽
插入透明校徽: ①先下载一个校徽: ②用矢量网站转换一下,这个免费的,很多其他的要钱钱: 位图转矢量图,JPG转矢量,PNG转矢量,GIF转矢量,BMP转矢量 - 在线工具 - 字客网 (fontke.com) 转换完了如下: 打…...

Linux系统部署PostgreSQL 单机数据库
安装方式 1 安装包方式 (Packages and Installers) 支持的操作系统包括 liunxMacosWindowsBSDSolaris 2 源码安装 (Source code) 下载源码包 通过下载地址PostgreSQL: File Browser 可以看到有各个版本的源码目录 选择13.1…...
好用的办公摸鱼神器
http://t.chaojizhu.cn/fawork/Down?uid180819...
手写Java序列化工具
一、思考 假设给一个java bean,让你按照 json 的格式打印出来,你会怎么做? 比如这个java bean 长这样,并且创建了一个叫宝儿姐的朋友 package com.test;public class User {private String name;private Integer age;private Bi…...

mysql面试题26:MySQL中什么是MVCC,它的底层原理是什么
该文章专注于面试,面试只要回答关键点即可,不需要对框架有非常深入的回答,如果你想应付面试,是足够了,抓住关键点 面试官:什么是MVCC,它的底层原理是什么? MVCC(Multi-Version Concurrency Control)是一种并发控制机制,用于在数据库中实现并发事务的隔离性和一致性…...

SQL进阶 - SQL的编程规范
性能优化是一个很有趣的探索方向,将耗时耗资源的查询优化下来也是一件很有成就感的事情,但既然编程是一种沟通手段,那每一个数据开发者就都有义务保证写出的代码逻辑清晰,具有很好的可读性。 目录 引子 小试牛刀 答案 引言 …...
生成xcframework
打包 XCFramework 的方法 XCFramework 是苹果推出的一种多平台二进制分发格式,可以包含多个架构和平台的代码。打包 XCFramework 通常用于分发库或框架。 使用 Xcode 命令行工具打包 通过 xcodebuild 命令可以打包 XCFramework。确保项目已经配置好需要支持的平台…...
LLM基础1_语言模型如何处理文本
基于GitHub项目:https://github.com/datawhalechina/llms-from-scratch-cn 工具介绍 tiktoken:OpenAI开发的专业"分词器" torch:Facebook开发的强力计算引擎,相当于超级计算器 理解词嵌入:给词语画"…...
【python异步多线程】异步多线程爬虫代码示例
claude生成的python多线程、异步代码示例,模拟20个网页的爬取,每个网页假设要0.5-2秒完成。 代码 Python多线程爬虫教程 核心概念 多线程:允许程序同时执行多个任务,提高IO密集型任务(如网络请求)的效率…...

IT供电系统绝缘监测及故障定位解决方案
随着新能源的快速发展,光伏电站、储能系统及充电设备已广泛应用于现代能源网络。在光伏领域,IT供电系统凭借其持续供电性好、安全性高等优势成为光伏首选,但在长期运行中,例如老化、潮湿、隐裂、机械损伤等问题会影响光伏板绝缘层…...

第 86 场周赛:矩阵中的幻方、钥匙和房间、将数组拆分成斐波那契序列、猜猜这个单词
Q1、[中等] 矩阵中的幻方 1、题目描述 3 x 3 的幻方是一个填充有 从 1 到 9 的不同数字的 3 x 3 矩阵,其中每行,每列以及两条对角线上的各数之和都相等。 给定一个由整数组成的row x col 的 grid,其中有多少个 3 3 的 “幻方” 子矩阵&am…...

【开发技术】.Net使用FFmpeg视频特定帧上绘制内容
目录 一、目的 二、解决方案 2.1 什么是FFmpeg 2.2 FFmpeg主要功能 2.3 使用Xabe.FFmpeg调用FFmpeg功能 2.4 使用 FFmpeg 的 drawbox 滤镜来绘制 ROI 三、总结 一、目的 当前市场上有很多目标检测智能识别的相关算法,当前调用一个医疗行业的AI识别算法后返回…...

Maven 概述、安装、配置、仓库、私服详解
目录 1、Maven 概述 1.1 Maven 的定义 1.2 Maven 解决的问题 1.3 Maven 的核心特性与优势 2、Maven 安装 2.1 下载 Maven 2.2 安装配置 Maven 2.3 测试安装 2.4 修改 Maven 本地仓库的默认路径 3、Maven 配置 3.1 配置本地仓库 3.2 配置 JDK 3.3 IDEA 配置本地 Ma…...
Java线上CPU飙高问题排查全指南
一、引言 在Java应用的线上运行环境中,CPU飙高是一个常见且棘手的性能问题。当系统出现CPU飙高时,通常会导致应用响应缓慢,甚至服务不可用,严重影响用户体验和业务运行。因此,掌握一套科学有效的CPU飙高问题排查方法&…...
纯 Java 项目(非 SpringBoot)集成 Mybatis-Plus 和 Mybatis-Plus-Join
纯 Java 项目(非 SpringBoot)集成 Mybatis-Plus 和 Mybatis-Plus-Join 1、依赖1.1、依赖版本1.2、pom.xml 2、代码2.1、SqlSession 构造器2.2、MybatisPlus代码生成器2.3、获取 config.yml 配置2.3.1、config.yml2.3.2、项目配置类 2.4、ftl 模板2.4.1、…...

解读《网络安全法》最新修订,把握网络安全新趋势
《网络安全法》自2017年施行以来,在维护网络空间安全方面发挥了重要作用。但随着网络环境的日益复杂,网络攻击、数据泄露等事件频发,现行法律已难以完全适应新的风险挑战。 2025年3月28日,国家网信办会同相关部门起草了《网络安全…...