从零开始的MySQL学习,完全备份、增量备份和备份恢复

2023-05-16

文章目录

  • 一、数据备份的重要性
  • 二、数据库备份的分类
    • 从物理与逻辑的角度
    • 从数据库的备份策略角度
  • 三、完全备份
    • 完全备份的优点
    • 完全备份的缺点
  • 四、mysqldump备份库
    • 备份单个库
    • 备份多个库
    • 备份所有库
    • 备份表
  • 五、备份恢复
    • source命令恢复
    • mysql命令恢复
  • 六、增量备份
    • 增量备份的优点
    • 增量备份的缺点
    • 增量备份恢复

一、数据备份的重要性

  • 在生产环境中,数据的安全性是至关重要的,任何数据的丢失都可能产生严重的后果
  • 造成数据丢失的原因:
    • 程序错误
    • 人为错误
    • 计算机失败
    • 磁盘失败
    • 灾难(如火灾、地震)和偷窃

二、数据库备份的分类

从物理与逻辑的角度

  • 物理备份:对数据库操作系统的物理文件(如数据文件、日志文件等)的备份,可以分为脱机备份(冷备份)和联机备份(热备份)。
    • 冷备份:是在关闭数据库的时候进行的。
    • 热备份:数据库处于运行状态,这种备份方法依赖于数据库的日志文件。
  • 逻辑备份:对数据库逻辑组件(如表等数据库对象)的备份。

从数据库的备份策略角度

  • 完全备份:每次对数据进行完整的备份
  • 差异备份:备份那些自从上次完全备份之后被修改过的文件
  • 增量备份:只有那些在上次完全备份或者增量备份后被修改的文件才会被备份

三、完全备份

  • 完全备份是对整个数据库的备份、数据库结构和文件结构的备份
  • 完全备份保存的是备份完成时刻的数据库
  • 完全备份是增量备份的基础

完全备份的优点

  • 备份与恢复操作简单方便。

完全备份的缺点

  • 数据存在大量的重复
  • 占用大量的备份空间
  • 备份与恢复时间长

四、mysqldump备份库

  • MySQL数据库的备份可以采用用多种方式
    • 直接打包数据库文件夹,如/usr/ocal/mysql/data
    • 使用专用备份工具mysqldump
  • mysqldump命令
    • MySQL自带的备份工具,相当方便对MySQl进行备份
    • 通过该命令工具可以将指定的库、表或全部的库导出为SQL脚本,在需要恢复时可进行数据恢复

备份单个库

  • mysqldump命令对单个库进行完全备份
mysqldump -u 用户名 -p[密码] [选项] [数据库名] > /备份路径/备份文件名

备份多个库

  • mysqldump命令对多个库进行完全备份
mysqldump -U用户名-P [密码] [选项] --databases 库名1 [库名2]... > /备份路径/备份文件名

备份所有库

  • 对所有库进行完全备份
mysqldump -u 用户名 -p[密码] [选项] --all-atabases > /备份路径/备份文件名

备份表

  • 对某个特定表进行备份
mysqldump -u用户名 -p[密码] [选项]数据库名 表名 > /备份路径/备份文件名

五、备份恢复

  • 使用mysqldump命令导出的SQL备份脚本,在进行数据恢复时可使用以下方法导入
    • source命令
    • mysql命令

source命令恢复

  • 使用source恢复数据库的步骤
    • 登录到MySQL数据库
    • 执行source 备份sql脚本的路径
      模拟环境:把数据库的表删除
use 数据库名;
drop table 表名;

source恢复

source 表备份的绝对路径;

mysql命令恢复

mysql -u用户名 -p[密码] 库名 < 表备份脚本的路径

六、增量备份

  • 使用mysqldump进行完全备份的存在的问题
    • 备份数据中有重复数据
    • 备份时间与恢复时间长

增量备份的优点

  • 没有重复的备份数据
  • 备份的数据量不大
  • 备份所需的时间也很短

增量备份的缺点

  • 备份恢复比较麻烦,需要用上次完全备份及完全备份之后所有的增量备份才能恢复。
  • 要对所有增量备份进行逐个反推恢复

增量备份恢复

1、增量备份需要开启MySQL的二进制日志功能

vi /etc/my.cnf

#在配置文件里[mysqld]下插入一行代码
log-bin=mysql-bin

#保存并重启服务
systemctl restart mysqld

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

2、创建新数据库,新建表,进行完全备份操作
在 /usr/local/mysql/data/目录下生成一个日志文件 mysql-bin.000001
在这里插入图片描述
在这里插入图片描述
在 /usr/local/mysql/data/目录下生成一个日志文件 mysql-bin.000001
在这里插入图片描述
3、刷新日志后生成一个新的增量备份日志文件 mysql-bin.000002
在这里插入图片描述
4、进行一些数据修改
在这里插入图片描述
再次刷新日志,生成增量备份日志文件 mysql-bin.000003
在这里插入图片描述
5、查看日志文件,记录错误操作位置和时间点
在这里插入图片描述
6、模拟故障:删除表info
在这里插入图片描述
7、进行恢复操作(使用三种不同方式)

  • 一般恢复
mysqlbinlog [--no-defaults] 增量备份文件 | mysql -u 用户名 -p
  • 基于位置恢复:
    在这里插入图片描述

a.恢复数据到指定位置

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

b.从指定的位置开始恢复数据

mysqlbinlog --start-position='操作id' 二进制日志 | mysql -u用户名 -p密码
  • 基于时间点恢复
    使用基于时间点的恢复,可能会出现在一个时间点里既同时存在正确的操作又存在错误的操作,所以我们需要一种更为精确的恢复方式
    a.从日志开头截止到某个时间点的恢复
mysqlbinlog [--no-defaults] --stop-datetime='年-月-日 小时:分钟:秒’ 二进制日志 | mysql -u用户名-p密码

b.从某个时间点到日志结尾的恢复

mysqlbinlog [--no-defaults] --start-datetime='年-月-日 小时:分钟:秒’ 二进制日志 | mysql -u用户名-p密码
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

从零开始的MySQL学习,完全备份、增量备份和备份恢复 的相关文章

  • 立创EDA绘板记录

    今天是第一次接触EDA xff0c 下载了立创的软件画板子 简单上b站看了立创十几分钟的入门教学视频 xff0c 刚好自己手边有51单片机的开发板和一个最小系统 xff0c 就决定自己动手画一个最小系统 最小系统主要由复位电路 xff0c
  • 02-线性结构2 一元多项式的乘法与加法运算 (20 分)

    02 线性结构2 一元多项式的乘法与加法运算 20 分 设计函数分别求两个一元多项式的乘积与和 输入格式 输入分2行 xff0c 每行分别先给出多项式非零项的个数 xff0c 再以指数递降方式输入一个多项式非零项系数和指数 xff08 绝对
  • 03-树2 List Leaves (25 分)

    03 树2 List Leaves 25 分 Given a tree you are supposed to list all the leaves in the order of top down and left to right I
  • Jupyter Notebook上使用tensorflow的血泪教训

    本文所涉及的环境为CUDA Version 10 1 105 xff0c tensorflow gpu2 3 0 xff0c python3 6 xff0c 本文不涉及任何配置环境的细节 xff0c 仅分享在Jupyter Notebook
  • java.sql.SQLNonTransientConnectionException: Could not create connection to database server

    使用JdbcTemplate连接数据库时发生错误 xff1a java sql SQLNonTransientConnectionException Could not create connection to x1f4a5 报错有这么长
  • Springboot集成Neo4j与Shiro冲突

    springboot集成neo4j时 xff0c 由于neo4j与shiro均包含名为 34 sessionFactory 34 的bean xff0c 项目启动时在生成neo4j的session对象时 createSharedSessio
  • 2.4 开发自己的Spring Boot项目

    Spring MVC的视图解析器的作用主要就是定位视图的 xff0c 也就是当控制器只是返回一个逻辑名称的时候 xff0c 是没有办法直接找到对应视图的 xff0c 这就需要视图解析器来解析了 在Maven的pom xml中加入JSP和JS
  • 3.1 IoC容器简介

    所有的IoC容器都需要实现接口BeanFactory xff0c 这是一个顶级的容器接口 BeanFactory接口源码 xff1a span class token comment span span class token commen
  • 3.2.1 通过扫描装配你的Bean

    对于扫描装配而言使用的注解是 64 Component和 64 ComponentScan 64 Component是标明哪个类被扫描进入IoC容器 xff0c 而 64 ComponentScan则是标明采用何种策略去扫描装配Bean 修
  • 3.5 使用属性文件

    可以采用默认为我们配置的application properties xff0c 也可以使用自定义的配置文件 引入属性文件依赖 span class token tag span class token tag span class tok
  • 3.6 条件装配Bean

    Bean初始化前 xff0c 对某些属性进行校验 xff0c 满足校验才去装配数据源 为了处理这样的场景 xff0c 需要用到 64 Conditional注解 xff0c 同时需要配合另外一个接口Condition xff08 org s
  • 3.7 Bean的作用域

    isSingleton方法如果返回true xff0c 则Bean在IoC容器中以单例存在 xff0c 这也是Spring IoC容器的默认值 xff1b 如果isPrototype方法返回true xff0c 则当我们每次获取Bean的时
  • 3.8 使用@Profile

    在企业开发的过程中 xff0c 项目往往要面临开发环境 测试环境 准生产环境和生产环境的切换 xff0c 每一套的上下文是不一样的 xff0c 它们有各自的数据库资源 Profile机制 xff1a 实现各个环境之间的切换 假设存在dev
  • 3.9 引入XML配置Bean

    注解 64 ImportResource xff1a 可以引入对应的XML文件 xff0c 用以加载Bean 有时候有些框架 xff08 如Dubbo xff0c Cat xff09 是基于Spring的XML方式进行开发的 xff0c 这
  • 第2章概述

    示例代码 xff1a span class token doctype span class token punctuation lt span span class token doctype tag DOCTYPE span span
  • 【无标题】

    简单接口HelloService span class token keyword public span span class token keyword interface span span class token class nam
  • 穷举法解华为bl锁

    穷举法解华为bl锁 python3代码测试截图 灵感来自于 xff1a https blog csdn net qq 40169767 article details 90481748 但是我不懂shell脚本 xff0c 那个脚本又运行不
  • 4.1.2 ProxyBean的实现

    代理 xff0c 可控制或增加对目标对象的访问 ProxyBean代码 xff1a span class token keyword package span span class token namespace com span clas
  • IDEA中打开.properties文件乱码

    问题 xff1a IDEA中打开 properties文件乱码 解决方法 xff1a 一 代开settings设置 二 搜索File Encodings 三 在Properties Files中选择编码格式为UTF 8 xff0c 注意一定
  • 怎么避免下载流氓软件,误下载后怎么处理

    经历复盘 xff1a 2022 1 20时 xff0c 为了下载SPSS时不小心下载了流氓软件 回过头来复盘一下 xff0c 一个是因为当时不小心点击了电信高速下载 xff0c 下载了一个P2P软件 点击安装的时候就感觉不太对劲 xff0c

随机推荐

  • eclipse查看不了源码怎么办

    问题 使用eclipse的过程中 xff0c 发现ctrl 43 鼠标左键 查看不了源码 解决方案 可以在弹出的提示框中添加源码的压缩包 xff0c 压缩包在你安装的jdk的根目录下 xff0c 如我的是C Application java
  • 关于if循环语句的四种写法

    if语句在java中起到判断语句的作用写法有四种 xff0c 如下 xff1a if if else if else if if else if else 例如 xff1a 一 xff1a if语句第一种写法 if 好处 xff1a 简单便
  • ROS学习——2编写简单的发布者和订阅者

    ros官网教程 xff1a 编写简单的发布者和订阅者 目录 c 43 43 版python版注意 c 43 43 版 在新建好的catkin ws工作空间下建立 cd catkin ws src 在该目录下创建自己的功能包 xff1a ca
  • ubuntu文件系统结构与磁盘管理

    一 根目录 xff1a Linux下 就是根目录 所有的目录都是由根目录衍生出来的 二 ubuntu 文件系统结构 xff1a 三 绝对路径和相对路径 xff1a 绝对路径 xff1a 从根目录 算起的路径 相对路径 xff1a 相对于目前
  • Framebuffer应用编程

    一 Framebuffer介绍 在Linux系统中通过Framebuffer xff08 帧缓冲 xff09 驱动程序来控制LCD Framebuffer就是一块内存 xff0c 里面保存着一帧图像 Framebuffer中保存着一帧图像的
  • Java编辑提示错误: 编码 GBK 的不可映射字符 (0x80)

    在DOS界面运行编译Java文件时提示错误 xff1a 编码 GBK 的不可映射字符 0x80 理解 xff1a java程序在编译的时候 xff0c 需要使用JDK开发工具包中的JAVAC EXE命令 xff0c 而JDK开发工具包是国际
  • makefile教程

    Makefile是一种用于构建软件项目的自动化工具 xff0c 通过定义一系列规则和依赖关系 xff0c 可以自动化构建 编译 测试和安装软件项目 在本篇教程中 xff0c 我将介绍如何编写一个简单的Makefile xff0c 并解释Ma
  • 原来制作数据可视化大屏这么简单,这三步就能完成

    不知道大家在对数据进行可视化处理的时候 xff0c 有没有碰到过以上问题 xff1f 身为一位经常需要整理数据 可视化处理的数据人 xff0c 我真的心有体会 随着越来越多的头部企业启动数据大屏展示公司的年度 战绩 xff0c 以数据大屏为
  • VirtualBox主机ping不通虚拟机

    问题 xff1a 虚拟机可以ping通主机 xff0c 主机无法ping通虚拟机 1 检查虚拟机是否配置好NAT网络连接 xff0c 从而能够ping通外网 2 配置主机ping虚拟机 xff0c 创建桥接网卡 3 检查虚拟机是否出现新建桥
  • MATLAB“在当前文件夹或MATLAB路径中未找到文件“的小“坑”

    更新 xff1a 似乎找到了官方依据 另外 xff0c 这个问题在MATLAB2020中似乎已经得到了修复 MATLAB文件夹的相关问题 新手使用matlab会遇到文件夹的问题 xff1a 第一 xff0c 新建一个脚本 xff0c Ctr
  • Ubuntu18.04下PX4+gazebo+QGC实现无人机在仿真环境下的房屋巡视

    前言 xff1a 老师给我布置了在仿真环境下模拟带摄像头的无人机在仿真环境下的巡视任务 xff0c 在完成任务的过程中 xff0c 遇到了很多问题 xff0c 查阅了许多博主的资料 xff0c 有些关键环节只是被一带而过 xff0c 导致安
  • 双系统下ubuntu18.04装拓展显示屏血泪史

    1 背景 xff1a 买了块新显示器 xff0c 想在ubuntu18 04下使用 xff0c 得装驱动 xff0c 刚开始按网上的一个教程 xff0c 直接把内核装坏了 xff0c 后来重装过系统才最终完成拓展屏的功能实现 xff0c 特
  • ROS工作空间、功能包创建,编译相关的C++/python程序详解

    有关工作空间的结构 xff1a WorkSpace 自定义的工作空间 build xff1a 编译空间 xff0c 用于存放CMake和catkin的缓存信息 配置信息和其他中间文件 devel xff1a 开发空间 xff0c 用于存放编
  • VScode配置ROS环境下Debug调试

    参考 xff1a VScode debug ROS cpp程序设置 断点调试 ABC Orange的博客 CSDN博客 poll failed with error interrupted system call Get Started w
  • C++速成(封装、继承和多态)

    前前言 xff1a 如果有时间 xff0c 搜一个完整的教程看 xff0c 用到啥学啥 xff0c 这样可能可以省更多的时间 61 61 前言 xff1a C 43 43 的命名规范 C 43 43 命名规范 ajioy的博客 CSDN博客
  • 神经网络与深度学习课程总结二

    深度学习平台介绍 1 1PyTorch是一个Python的深度学习库 它最初由Facebook人工智能研 究小组开发 xff0c 而优步的Pyro软件则用于概率编程 1 1 1PyTorch基本使用 基本概念 张量 xff08 Tensor
  • 神经网络与深度学习课程总结三

    一 数据集与评价指标 算法评估 xff1a P R曲线 mAP计算 二 目标检测与YOLO 目标检测问题 xff1a 目标检测是在给定的图片中精确找到物体所在位置 并标注出物体的类别 物体的尺寸变化范围很大 摆放物体的角度 姿态不定 而且可
  • 神经网络与深度学习课程总结四

    一 数据处理基础 1 1特征编码 xff1a 第1列表示年龄 xff0c 是一个数值特征 第2列表示性别 xff0c 是一个只有一位 xff08 0 xff0c 1 xff09 的特征 0 gt Male 1 gt Female 第3列表示
  • 高大上的数据可视化图表,只需6步就能完成

    一份高质量的数据可视化图表 xff0c 能够让你清晰 全面地传达出数据信息 xff0c 成为你工作 学习 竞赛的助推器 xff01 因此 xff0c 一款功能强大的可视化软件显得尤为重要 xff01 最近博主在用的百度 Sugar BI x
  • 从零开始的MySQL学习,完全备份、增量备份和备份恢复

    文章目录 一 数据备份的重要性二 数据库备份的分类从物理与逻辑的角度从数据库的备份策略角度 三 完全备份完全备份的优点完全备份的缺点 四 mysqldump备份库备份单个库备份多个库备份所有库备份表 五 备份恢复source命令恢复mysq