当前位置: 首页 > news >正文

Mysql数据的备份与恢复

一.备份概述

        备份的主要目的是灾难恢复,备份还可以测试应用、回滚数据修改、查询历史数据、审计等。

1.数据备份的重要性

         在企业中数据的价值至关重要,数据保障了企业业务的正常运行。因此,数据的安全性及数据的可靠性是运维的重中之重,任何数据的丢失都可能对企业产生严重的后果。通常情况下造成数据丢失的原因有如下几种:

  1. 程序错误。
  2.  人为操作错误
  3. 运算错误。
  4. 磁盘故障。
  5. 灾难(如火灾、地震)和盗窃。

2.数据库备份类型

(1)从物理与逻辑的角度分类

        数据库备份可以分为物理备份和逻辑备份。物理备份是对数据库操作系统的物理文件(如数据文件、口志文件等)的备份。这种类型的备份适用于在出现问题时需要快速恢复的大型重要数据库。

        物理备份又可以分为冷备份(脱机备份)、热备份(联机备份)和温备份。

  • 冷备份:在数据库关闭状态下进行备份操作。
  • 热备份:在数据处于运行状态时进行备份操作,该备份方法依赖数据库的日志文件。
  • 温备份:数据库锁定表格(不可写入但可读)的状态下进行备份操作。

        逻辑备份是对数据库逻辑组件的备份(如表等数据库对象),表示为逻辑数据库结构和内容的信息。这种类型的备份适用于可以编辑数据值或表结构较小的数据量,或者在不同的机器体系结构上重新创建数据。

(2) 从数据库的备份策略角度分类

从数据库的各份策略角度,数据库的各份可分为完全备份、差异各份和增量备份。

  • 完全备份:每次对数据进行完整的备份,即对整个数据库、数据库结构和文件结构的备份,保存的是备份完成时刻的数据库,是差异备份与增量备份的基础。完全备份的备份与恢复操作都非常简单方便,但是数据存在大量的重复,并且会占用大量的磁盘空间,各份的时间也很长。
  • 差异备份:备份那些自从上次完全备份之后被修改过的所有文件,备份的时间节点是从上次完整备份起,备份数据量会越来越大。恢复数据时,只需恢复上次的完全备份与最近的次差异备份。
  •  增量备份:只有那些在上次完全备份或者增量备份后被修改的文件才会被备份。以上次完整备份或上次增量备份的时间为时间点,仅备份这之间的数据变化,因而备份的数据量小,占用空间小,备份速度快。但恢复时,需要从上一次的完整备份开始到最后一次增量备份之间的所有增量依次恢复,如中间某次的各份数据损坏,将导致数据的丢失

3.常见的备份方法

         MySQL数据库的各份可以采用很多种方式,如直接打包数据库文件(物理冷备份)、专用备份工具(mysqldump)、二进制日志增量备份、第三方工具备份等。

(1)物理冷备份

        物理冷备份时需要在数据库处于关闭状态下,能够较好地保证数据库的完整性。物理冷备份一般用于非核心业务,这类业务一般都允许中断,物理冷备份的特点就是速度快,恢复时也是最为简单的。通常通过直接打包数据库文件夹(本章中的数据库文件夹位于usrlocal/mysqldata)来实现备份。

(2)专用备份工具mysqldump或mysqihotcopy

         mysqldump程序和mysqlhotcopy都可以做备份。mysqldump是客户端常用逻辑备份程序,能够产生一组被执行以后再现原始数据库对象定义和表数据的SQL语句。它可以转储一个到多个MySQL数据库,对其进行备份或传输到远程SQL服务器。mysqldump更为通用,因为它可以备份各种表。mysqlhotcopy仅适用于某些存储引擎。

          mysqlhotcopy是由TimBunce最初编写和贡献的Perl脚本。mysqlhotcopy仅用于备份MyISAM和ARCHIVE表。它只能运行在UNI或Linux上。因为使用范围很小,因此本文中不做详细介绍,如果同学们有兴趣可以在课下研究。

(3)通过启用二进制日志进行增量备份

         MySQL支持增量备份,进行增量备份时必须启用二进制日志。二进制日志文件为用户提供复制,对执行备份点后进行的数据库更改所需的信息进行恢复。如果进行增量备份(包含自上次完全备份或增量各份以来发生的数据修改),需要刷新二进制日志。

(4)通过第三方工具备份

        PerconaXtraBackup是一个免费的MySQL热备份软件,支持在线热备份Innodb和XtraDB,也可以支持MySQL表备份,不过MyISAM表的各份要在表锁的情况下进行。

二.数据库完全备份操作

1.物理冷备份与恢复

(1)先关闭mysqld服务

[root@localhost ~]# systemctl stop mysqld

(2)创建一个存储目录

[root@localhost ~]# mkdir /backup

 (3)使用tar创建备份文件

[root@localhost local]# tar zcvf /backup/mysql_$(date +%F).tar.gz mysql/

(4)恢复数据库

[root@localhost ~]# systemctl stop mysqld
[root@localhost ~]# cd /backup/
[root@localhost backup]# tar zxvf mysql_2023-06-08.tar.gz[root@localhost backup]# cd /usr/local/
[root@localhost local]# mv mysql/ mysql.bak[root@localhost local]# cd /backup/
[root@localhost backup]# mv mysql /usr/local/
[root@localhost backup]# systemctl start mysqld
[root@localhost backup]# mysql -u root -p -e 'select * from auth.users;'

2.mysqldump备份与恢复

        通过mysqldump命令可以将指定的库,表或全部的库导出为SQL脚本,便于该命令在不同版本的MySQL服务器上使用。例如,当需要升级MySQL服务器时,可以先试用mysqldump命令将原有库信息导出,然后直接在升级后的MySQL服务器中导入即可。

(1)备份数据库

        使用mysqldump命令导出数据时,默认会直接在终端显示,若要保存到文件,还需要结合Shell的“>重定向输出操作。

模式一:备份指定库中的部分表

mysqldump 【选项】 库名 【表名1】 【表名2】…>/备份文件路径/文件名

模式二:备份一个或多个完整的库

mysqldump 【选项】 --database 库名1 库名2…>/备份文件路径/文件名

 模式三:备份MySQL服务器中所有的库

mysqldump 【选项】 --all-databases>/备份路径/备份文件名

备注:常用的选项包括“-u”,“-p”,分别用于指定数据库的用户和密码,当导出的数据量较大时,可以添加“--opt”选项以优化执行速度

(2)恢复数据库

        使用mysqldump命令导出的SQL备份脚本,在需要恢复时可以通过mysql命令对其进行导入操作,格式:

mysql 【选项】【库名】 【表名】</备份路径/备份文件名

 三.mysql增量备份与恢复

         使用mysqldump进行完全备份,备份的数据中有重复数据,份时间与恢复时间过长而增量备份就是自上一次备份之后增加或改变的内容

1.特点:

        与完全备份不同,增量备份没有重复数据,备份量不大,时间短:但其恢复麻烦,需要上次完全备份及完全备份之后所有的增量备份才能恢复,而且要对所有增量备份进行逐个反推恢复。MySQL没有提供直接的增量备份办法,可以通过MySQL提供的二进制日志(binanylogs)间接实现增量备份。 

2.意义

        进制日志保存了所有更新数据库的操作。二进制日志在启动MySQL服务器后开始记录,并在文件达到二进制日志所设置的最大值或者接收到flush logs命令后重新创建新的日志文件,生成二进制文件序列,并及时把这些日志保存到安全的存储位置,即可完成一个时间段的增量备份。使用max_binlog_size配置项可以设置二进制口志文件的最大值,如果二进制文件的大小超过了max_binlog_size  它就会自动创建新的二进制文件

3.增量备份

        要进行MySQL的增量备份,首先要开启二进制日志功能。开启MySQL的二进制日志功能的实现方法有很多种,最常用的是在MySQL配置文件的mysqld项加入“log-bin=/文件路径/文件名”前,如log-bin=/usr/local/mysql/mysql-bin,然后重启MySQL服务就可以在指定路径下查看二进制日志文件了。默认情况下,二进制日志文件的扩展名是一个六位的数字,如mysql-bin.000001

 (1)修改MySQL主配置文件my.cnf

在[mysqld]模块中添加log-bin=mysql-binserver-id=1binlog——format=MIXED[root@localhost ~]# systemctl restart mysqld

(2)生成日志内容

[root@localhost ~]# cd /usr/local/mysql/data/
[root@localhost data]# mysqladmin -u root -p flush-logs

(3)查看新的日志文件

mysqlbinlog --no-defaults mysql-bin.000002
注意:如果sql语句被加密了,可以使用以下指令
mysqlbinlog --no-defaults --base64-output=DECODE-ROWS mysql-bin.000002

4.MySQL增量恢复

         常用的增量恢复的方法有三种:一般恢复、基子位置的恢复、基于时间点的恢复般恢复:将所有备份的二进制日志内容全部恢复,命令格式如下所示。

1.一般恢复:

将所有备份的二进制日志内容全部恢复,命令格式如下:

mysqlbinlog  --no-defaults 增量备份文件 | mysql -u 用户 -p 密码
2.基于位置恢复:

数据库管理员在操作数据库时可能在同一时间点既有错误的操作也有正确的操作,通过基于位置进行恢复可以使恢复更加精确。 

(1)恢复数据到指定位置

mysqlbinlog --stop-position=操作id 二进制日志 | mysql -u 用户名 -p 密码

 (2)从指定的位置开始恢复

mysqlbinlog --start-opsition=操作id 二进制日志 | mysql -u 用户名 -p 密码
3.基于时间点 :

跳过某个发生错误的时间点实现数据恢复,而基于时间点的恢复可以分为三种情况

(1)从日志开头截止到某个时间点

mysqlbinlog --no-defaults --stop-datetime=时间 二进制日志 | mysql -u 用户 -p 密码

(2)从某个时间点到日志结尾的恢复

mysqlbinlog --no-defaults --start-detatime=时间 二进制日志 | grep -u 用户名 -p 密码

(3)从某个时间点到某个时间点的恢复

mysqlbinlog --no-defaults --start-datetime=时间 --stop-datetime=时间 二进制日志 | mysql -u 用户名 -p 密码

相关文章:

Mysql数据的备份与恢复

一.备份概述 备份的主要目的是灾难恢复&#xff0c;备份还可以测试应用、回滚数据修改、查询历史数据、审计等。 1.数据备份的重要性 在企业中数据的价值至关重要&#xff0c;数据保障了企业业务的正常运行。因此&#xff0c;数据的安全性及数据的可靠性是运维的重中之重&…...

规上!西安市支持培育商贸企业达限纳统应统尽统申报奖励补助要求政策

西安市支持培育商贸企业达限纳统应统尽统工作方案 为加快培育消费市场主体&#xff0c;支持商贸企业扩大经营、做大做强&#xff0c;指导企业达限纳统、应统尽统&#xff0c;不断扩大我市限额以上商贸企业数量规模&#xff0c;促进全市经济社会高质量发展&#xff0c;结合我市…...

Go语言测试第二弹——基准测试

在前一篇文章中&#xff0c;我们讲解了Go语言中最基础的单元测试&#xff0c;还没有看过的可以自行去查看&#xff0c;这篇文章我们详细了解Go语言里面的基准测试。 基准测试 基准测试&#xff0c;也就是BenchmarkTest&#xff0c;基准测试是用来测试代码性能的的一种方法&…...

关于“刘亦菲为什么无人敢娶”的问题❗❗❗

关于“刘亦菲为什么无人敢娶”的问题&#xff0c; 实际上涉及到多个方面的因素&#xff0c; 以下是对这些因素的详细分析&#xff1a;1.事业心重&#xff1a;刘亦菲作为华语影视圈的知名女星&#xff0c;她的演艺事业非常成功&#xff0c; 这也意味着她将大量的时间和精力投…...

LeetCode:经典题之141、142 题解及延伸

系列目录 88.合并两个有序数组 52.螺旋数组 567.字符串的排列 643.子数组最大平均数 150.逆波兰表达式 61.旋转链表 160.相交链表 83.删除排序链表中的重复元素 389.找不同 1491.去掉最低工资和最高工资后的工资平均值 896.单调序列 206.反转链表 92.反转链表II 141.环形链表 …...

rk3568 OpenHarmony 串口uart与电脑通讯开发案例

一、需求描述&#xff1a; rk3568开发板运行OpenHarmony4.0&#xff0c;通过开发板上的uart串口与电脑进行通讯&#xff0c;相互收发字符串。 二、案例展示 1、开发环境&#xff1a; &#xff08;1&#xff09;rk3568开发板 &#xff08;2&#xff09;系统&#xff1a;OpenHar…...

canvas画布旋转问题

先说一下为什么要旋转的目的&#xff1a;因为在画布上签名&#xff0c;在不同的设备上我需要不同方向的签名图片&#xff0c;电脑是横屏&#xff0c;手机就是竖屏&#xff0c;所以需要把手机的签名旋转270&#xff0c;因此写了这个方法。 关于画布旋转的重点就是获取到你的画布…...

vue3 【提效】自动导入框架方法 unplugin-auto-import 实用教程

是否还在为每次都需要导入框架方法而烦恼呢&#xff1f; // 每次都需手动导入框架方法 import { ref } from vuelet num ref(0)用 unplugin-auto-import 来帮你吧&#xff0c;以后只需这样写就行啦&#xff01; let num ref(0)官方示例如下图 使用流程 1. 安装 unplugin-au…...

clip系列改进Lseg、 group ViT、ViLD、Glip

Lseg 在clip后面加一个分割head&#xff0c;然后用分割数据集有监督训练。textencoder使用clip&#xff0c;frozen住。 group ViT 与Lseg不同&#xff0c;借鉴了clip做了真正的无监督学习。 具体的通过group block来做的。使用学习的N个group token&#xff08;可以理解为聚类…...

Ubuntu下TensorRT与trtexec工具的安装

新版&#xff08;这里测试的是10.1版&#xff09;的onnx转tensorrt engine工具trtexec已经集成在TensorRT中&#xff0c;不需要额外单独安装。 教程来源于此网页&#xff1a;https://medium.com/moshiur.faisal01/install-tensorrt-with-command-line-wrapper-trtexec-on-unun…...

MySQL定时任务

事件调度器操作 查看事件调度器是否开启&#xff1a;ON 表示已开启。 show variables like %event_scheduler%; ------------------------ | Variable_name | Value | ------------------------ | event_scheduler | ON | ------------------------ 开启和关闭事件调度器…...

Pandas实用Excel数据汇总

Pandas 是一个开源的 Python 库&#xff0c;由 Wes McKinney 开发&#xff0c;专门用于高效地处理和分析数据&#xff0c;无论是小规模的数据实验还是大规模的数据处理任务。它构建在 NumPy 之上&#xff0c;这意味着它利用了 NumPy 的高性能数组计算能力。Pandas 的核心数据结…...

【计算机网络】[第4章 网络层][自用]

1 概述 (1)因特网使用的TCP/IP协议体系(四层)的网际层,提供的是无连接、不可靠的数据报服务; (2)ATM、帧中继、X.25的OSI体系(七层)中的网络层,提供的是面向连接的、可靠的虚电路服务。 (3)路由选择分两种: 一种是由用户or管理员人工进行配置(只适用于规…...

Unity3D Entity_CacheService实现详解

Unity3D是一款广泛使用的游戏开发引擎&#xff0c;它提供了丰富的功能和工具来帮助开发者创建高质量的游戏和互动体验。在Unity开发过程中&#xff0c;资源管理是一个重要的环节&#xff0c;特别是当项目规模逐渐增大&#xff0c;资源数量变多时。为了优化资源的加载和管理&…...

DLMS/COSEM协议—(Green-Book)Gateway protocol

DLMS/COSEM协议 — Gateway protocol 10.10 Gateway protocol &#xff08;网关协议&#xff09;10.10.1 概述10.10.2 网关协议 &#xff08;The gateway protocol&#xff09;10.10.3 HES在WAN/NN中作为发起者&#xff08;拉取操作&#xff09;10.10.4 LAN中的终端设备作为发起…...

Android高级面试_12_项目经验梳理

Android 高级面试-1&#xff1a;Handler 相关 问题&#xff1a;Handler 实现机制&#xff08;很多细节需要关注&#xff1a;如线程如何建立和退出消息循环等等&#xff09; 问题&#xff1a;关于 Handler&#xff0c;在任何地方 new Handler 都是什么线程下? 问题&#xff1a…...

【项目实训】解决前后端跨域问题

由于前端框架使用vue&#xff0c;后端使用flask&#xff0c;因此需要解决前后端通信问题 在vue.config.js中修改 module.exports defineConfig({transpileDependencies: true,lintOnSave:false, }) // 跨域配置 module.exports {devServer: { //记住&#x…...

Java反射API详解与应用场景

一、Java反射API简介: 一、什么是反射: 反射是一种强大的工具,它允许我们在运行时检查类、方法和字段的信息,甚至允许我们动态的调用特定类的方法或改变字段的值。编程语言中的反射机制通常用于从类、对象或方法中检索元数据,或者更特别的说,从代码本身中获取信息。这就…...

【例子】webpack 开发一个可以加载 markdown 文件的加载器 loader 案例

Loader 作为 Webpack 的核心机制&#xff0c;内部的工作原理却非常简单。接下来我们一起来开发一个自己的 Loader&#xff0c;通过这个开发过程再来深入了解 Loader 的工作原理。 这里我的需求是开发一个可以加载 markdown 文件的加载器&#xff0c;以便可以在代码中直接导入 m…...

揭秘!这款电路设计工具让学校师生都爱不释手——SmartEDA的魔力何在?

随着科技的飞速发展&#xff0c;电子设计已成为学校师生们不可或缺的技能之一。而在众多的电路设计工具中&#xff0c;有一款名为SmartEDA的工具&#xff0c;凭借其强大的功能和友好的用户体验&#xff0c;迅速赢得了广大师生的青睐。今天&#xff0c;就让我们一起探索SmartEDA…...

onlyoffice实现打开文档的功能

后端代码 import api from api import middlewareasync def doc_callback(request):data await api.req.get_json(request)print("callback ", data)# status 2 文档准备好被保存# status 6 文档编辑会话关闭return api.resp.success()app api.Api(routes[api.…...

基于 SpringBoot + Vue 的图书购物商城项目

本项目是一个基于 SpringBoot 和 Vue 的图书购物商城系统。系统主要实现了用户注册、登录&#xff0c;图书浏览、查询、加购&#xff0c;购物车管理&#xff0c;订单结算&#xff0c;会员折扣&#xff0c;下单&#xff0c;个人订单管理&#xff0c;书籍及分类管理&#xff0c;用…...

如何使用kimi智能助手:您的智能生活小助手

Kimi智能助手是一款功能强大的AI工具&#xff0c;旨在帮助用户提高工作效率和生活品质。下面小编将详细介绍如何使用Kimi智能助手&#xff0c;涵盖其主要功能以及一些实用技巧。 一、Kimi智能助手的主要功能 多语言对话能力&#xff1a;Kimi擅长中文和英文的对话&#xff0c;可…...

sql操作

1. 按条件将表A的数据更新到表B中&#xff1a; update B b set b.col1 (select col1 from A a where b. id a.code), b.col2 (select col2 from A a where b. id a.code), ………… 2. 将表A的全量数据插入到表B中 insert into B (col1, col2, col3, col4,……&am…...

开关电源调试记录-基于DK112(DK1203也一样)作为开关主控芯片的开关电源

调试了一款DK112&#xff08;datasheet&#xff09;开关电源控制芯片。 1、原理图如下&#xff1a; 2、测试波形 a.输出波形&#xff0c;图中标识“5V”的位置 b.芯片VCC引脚&#xff0c;图中标识“4”的位置 c.芯片FB引脚&#xff0c;图中标识“3”的位置 对于FB引脚&…...

【自然语言处理】GPT-5技术突破预测:引领自然语言处理革新的里程碑

摘要 随着科技的飞速发展&#xff0c;人工智能&#xff08;AI&#xff09;领域正迎来一场前所未有的革命。近日&#xff0c;OpenAI首席技术官米拉穆拉蒂在采访中透露&#xff0c;新一代大语言模型GPT-5将在一年半后发布&#xff0c;这一消息无疑在科技界掀起了巨大的波澜。GPT-…...

qt基本窗口类(QWidget,QDialog,QMainWindow)

1.三个基本窗口类 1.1QWidget 所有窗口的基类 可以内嵌到其他窗口的内部&#xff0c;无边框 也可以作为独立窗口显示&#xff0c;有边框 1.2QDialog 继承于QWidget 对话框窗口类 不可以内嵌到其他窗口 有模态和非模态两种显示方式 1.3QMainWind 继承于QWidget 主窗口类 不可以…...

最新收录历年地震数据,含时间、位置、类型、震级等信息

基本信息. 数据名称: 历年地震数据 数据格式: Shp 数据时间: 2023年 数据几何类型: 点 数据坐标系: WGS84坐标系 数据来源&#xff1a;网络公开数据 数据字段&#xff1a; 序号字段名称字段说明1dzlx地震类型2zj震级3zysd震源深度&#xff08;米&#xff09;4jtwz…...

C++ 串口读写

这段代码演示了如何使用 Windows API 中的串口通信功能进行简单的数据发送和接收。它使用了串口的基本操作和设置,并通过 sendSizeCategory 函数实现了一个简单的串口通信示例,发送一个十六进制数据,并读取串口返回的数据。 _CRT_SECURE_NO_WARNINGS:这是针对使用 strcpy …...

WebRTC系列实战-自定义RTP中的extension

文章目录 1. 新增extensionsId;1.1 新增自定义extension1.2 准备添加到sdp相关操作1.3 对header长度返回的修改:2. 自定义extesion的写入及注册到extensionMap中2.1 添加到RTPheader中2.2. 大小限制2.3. 是否注册限制2.4. 自定义extension注册需要修改的位置3.接收端解析及注…...

国外优秀设计网站推荐/b2b平台

双碳计算中涉及到的单位换算 在双碳&#xff08;碳中和与碳排放&#xff09;计算当中&#xff0c;经常会对吸收或者排放的碳 C或二氧化碳 CO₂进行定量表达&#xff0c;比如常用植被NPP&#xff08;Net Primary Productivity&#xff0c;净初级生产力&#xff09;来表示植被吸…...

电影网站设计模板/专业搜索引擎seo公司

编程新手猜数字游戏 #include <stdio.h> #include <time.h> #include<stdlib.h> void main() { srand(time(0)); int n rand() % 100 1,c 0,a 0; printf("我有一个1-100的随机数,你猜是多少&#xff1a;>"); do { scanf("%d", &…...

如何做众筹网站/seo工具网站

Lodop中有两种专门给超文本表格的方式&#xff0c;ADD_PRINT_TABLE和ADD_PRINT_TBURL&#xff0c;该方式只能用于单个表格&#xff0c;表格外的内容不显示&#xff0c;是专门用于打印html超文本表格的。使用这两个语句&#xff0c;内容在thead和tfoot标签内&#xff0c;被当做页…...

做钢结构网站有哪些/免费seo在线优化

我们都知道调用WCF直接在Service References中引用可以远程调用的WCF Url就行了。 但是我们想过没&#xff0c;在Development环境中可以这样做&#xff0c;但是QA、UAT、Production上我们怎么做呢&#xff1f; WCF的通信方式主要有Http和Tcp&#xff0c;这次我们用Http。 好了&…...

武汉做网站哪个好/seo优化一般包括哪些

inv[i](M-M/i)*inv[M%i]%M 转载于:https://www.cnblogs.com/autsky-jadek/p/7769055.html...

设计购物网站的意义/seo技术蜘蛛屯

大众观点&#xff1a;免费 低价值 &#xff0c; 付费 高价值。 人们的潜意识总会偏向免费就是低价值&#xff0c;这道理用在泡妞上也是一样的。 曾经有个朋友请教我一个问题&#xff0c;他说&#xff1a;“我经常给她买东西&#xff0c;她有困难我都帮她了&#xff0c;还是对…...