二进制日志备份与恢复

news2025/1/16 1:04:51

二进制备份是 MySQL 数据库备份的一种方式,它通过记录数据库的所有更改操作,以二进制格式保存,实现对数据库的增量备份和恢复。binlog_format 是 MySQL 中用来指定二进制日志格式的参数,有三种常见的选项:STATEMENTROWMIXED。不同的选项会影响到二进制日志的记录方式和内容。下面详细解释二进制备份以及不同 binlog_format 选项的区别:

1. 二进制备份

定义:
  • 二进制备份是指备份 MySQL 数据库的二进制日志文件,这些日志记录了数据库发生的所有更改操作。
  • 二进制备份通常用于增量备份和恢复,只备份从上次备份或上次差异备份以来发生的数据变更,节省了备份时间和存储空间。
操作步骤:
  1. 启用二进制日志功能。
  2. 使用 mysqlbinlog 命令将二进制日志文件导出到文本文件。
  3. 在需要恢复数据时,使用 mysqlbinlog 命令将备份的二进制日志文件应用到数据库中。

2. binlog_format 不同选项的区别

在 MySQL 中,binlog_format 参数用来指定二进制日志的格式,有三种常见的选项:STATEMENTROWMIXED。不同的选项会影响到二进制日志记录的方式和内容。

1. STATEMENT
  • 说明: binlog_format=STATEMENT 表示二进制日志以 SQL 语句的形式记录。
  • 特点:
    • 记录了执行的 SQL 语句,比如 INSERT、UPDATE、DELETE 等。
    • 适用于非常复杂的 SQL 语句,或者需要在不同数据库间进行复制时。
  • 优点:
    • 日志文件相对较小。
    • 可读性较好,便于查看和分析。
  • 缺点:
    • 在某些情况下可能会导致数据不一致的问题,例如使用了不确定的函数或变量。
    • 在使用不支持的语法时可能会出现错误。
2. ROW
  • 说明: binlog_format=ROW 表示二进制日志以行的形式记录。
  • 特点:
    • 记录了数据行的变化,即记录了被修改的行的内容。
    • 适用于大部分的数据更改场景,对于一些复杂的语句也能够保证正确性。
  • 优点:
    • 数据更改的具体内容被记录,恢复时更加准确。
    • 不会受到 SQL 语句语法的影响。
  • 缺点:
    • 日志文件相对较大,占用存储空间较多。
    • 在某些情况下可能会导致主从复制的延迟。
3. MIXED
  • 说明: binlog_format=MIXED 表示二进制日志同时采用了 STATEMENT 和 ROW 两种方式。
  • 特点:
    • 在不同情况下自动选择使用 STATEMENT 或 ROW 方式记录。
    • 对于某些语句使用 STATEMENT,对于某些语句使用 ROW。
  • 优点:
    • 综合了 STATEMENT 和 ROW 的优点,适用范围更广。
    • 可以在不同场景下灵活选择合适的记录方式。
  • 缺点:
    • 日志文件大小和性能可能存在波动。

3. 如何选择 binlog_format 选项

  • STATEMENT: 适用于不涉及函数、变量等复杂语法的场景,日志文件相对较小,便于查看和分析。
  • ROW: 适用于大部分的数据更改场景,对于需要准确恢复数据的场景较为合适,但日志文件会相对较大。
  • MIXED: 综合了 STATEMENT 和 ROW 的优点,适用范围更广,可以在不同场景下灵活选择合适的记录方式,是推荐使用的方式。

示例:

mysqlbinlog --no-defaults --base64-output=decode-rows -v /usr/local/mysql/data/mysql-bin.000001 

这是使用 mysqlbinlog 命令查看 /usr/local/mysql/data/mysql-bin.000001 文件的部分输出结果,并且使用了一些参数:

  • --no-defaults:  默认字符集,防止出现UTF-8报错。
  • --base64-output=decode-rows: 表示将行事件的内容使用 base64 解码输出。
  • -v: 表示显示详细的日志内容。

这个命令的目的是查看二进制日志文件的详细内容,并将行事件的内容进行 base64 解码后显示,以便更容易阅读和理解。

对数据库进行操作以增加日志记录

删除class2后回滚


 

验证:

mysqlbinlog --no-defaults --start-position='388' --stop-position='1052' /usr/local/mysql/data/mysql-bin.000002 | mysql -uroot -p123456

--start-position='388'  表示从位置388开始

--stop-position='1052'  表示到位置1052结束

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

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

相关文章

就业班 第二阶段 2401--3.26 day6 Shell初识 连接vscode

远程连接vs_code可能出现的问题 C:\Users\41703\.ssh 验证远程主机的身份,如果连不上vscode,可以尝试删除这里面的公钥代码。 重新安装那个扩展,排除扩展本身的问题 谁连过我,并操作了什么 curl https://gitea.beyourself.org.c…

pytorch反向传播算法

目录 1. 链式法则复习2. 多输出感知机3. 多层感知机4. 多层感知机梯度推导5. 反向传播的总结 1. 链式法则复习 2. 多输出感知机 3. 多层感知机 如图: 4. 多层感知机梯度推导 简化式子把( O k O_k Ok​ - t k t_k tk​) O k O_k Ok​(1 - O k O_k Ok​)起个别名…

HeidiSQL导出SQL文件

目前开发阶段的数据库可视化工具逐渐转为了HeidiSQL,本文讲一讲导出到sql文件的小细节,给自己做个记录补充。 安装或数据库可视化工具比较可参考: windows下全免费手动搭建php8mysql8开发环境及可视化工具安装 导出 原来用Navicat的时候&am…

Salesforce宣布将停用Workflow Rules和Process Builder!

在近期的公告中,Salesforce透露在2025年12月31日之后将不再支持Workflow Rules和Process Builder。 Salesforce敦促用户在截止日期前将其自动化流程迁移到Flow Builder,以确保不间断的支持和漏洞修复。此举正值Salesforce将重点转向更现代、可扩展、低代…

Go语言学习Day4:函数(上)

名人说:莫愁千里路,自有到来风。 ——钱珝 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 目录 1、函数的概念与定义①函数的概念②函数的具体定义③多返回值 2、函数参数与作用域①可变参数②形…

【Ubuntu】在Ubuntu中实现酣畅淋漓的性能释放:调整CPU频率

一、问题描述 在机器人开发中,经常需要运行诸如 SLAM 和 Planning 等 CPU 密集型程序,这些程序需要充分发挥计算机的性能,以确保算法的高效运行。然而,默认情况下,Ubuntu 通常将 CPU 设置为节能模式,导致 …

设计模式之组合模式解析

组合模式 1)概述 1.定义 组合多个对象形成树形结构以表示具有“整体—部分”关系的层次结构。 组合模式对单个对象(即叶子对象)和组合对象(即容器对象)的使用具有一致性,组合模式又称为“整体—部分”(…

发送请求- header配置

请求头里是客户端的要求,把你的诉求告诉服务端,服务端按照你的要求返回数据 , 请求header需要严格全配置,把请求header全部传入,不能频繁访问,让后端知道它是正常请求 一般只配置User-Agent和Content Typ…

docker 搜索镜像命令

docker 搜索镜像命令 命令格式 docker search 关键字 如:docker centos 结果 result :

JVM(三)——字节码技术

三、字节码技术 1、类文件结构 一个简单的 HelloWorld.java package com.mysite.jvm.t5; // HelloWorld 示例 public class HelloWorld {public static void main(String[] args) {System.out.println("hello world");} }执行 javac -parameters -d . HellowWorld.…

零拷贝技术、常见实现方案、Kafka中的零拷贝技术的使用、Kafka为什么这么快

目录 1. 普通拷贝 2. 数据拷贝基础过程 2.1 仅CPU方式 2.2 CPU&DMA方式 3.普通模式数据交互 4. 零拷贝技术 4.1 出现原因 4.2 解决思路 4.2.1 mmap方式 4.2.2 sendfile方式 4.2.3 sendfileDMA收集 4.2.4 splice方式 5. Kafka中使用到的零拷贝技术 参考链接 本…

如何使用 ChatGPT 进行编码和编程

文章目录 一、初学者1.1 生成代码片段1.2 解释功能 二、自信的初学者2.1 修复错误2.2 完成部分代码 三、中级水平3.1 研究库3.2 改进旧代码 四、进阶水平4.1 比较示例代码4.2 编程语言之间的翻译 五、专业人士5.1 模拟 Linux 终端 总结 大多数程序员都知道,ChatGPT …

【二叉树】Leetcode 94. 二叉树的中序遍历【简单】

二叉树的中序遍历 给定一个二叉树的根节点 root ,返回 它的 中序 遍历 。 示例 1: 输入:root [1,null,2,3] 输出:[1,3,2] 解题思路 中序遍历是一种二叉树遍历方式,按照“左根右”的顺序遍历二叉树节点。 1、递归…

基于单片机的智能汽车防盗系统设计

摘要:本文介绍了一种以汽车专用单片机飞思卡尔MC68HC908QT4CPE 作为底层主控芯片,人体远红外热释传感器、防闯入光幕墙及振动传感器作为检测装置的汽车防盗系统。单片机将检测到的防盗传感器开关信号,通过数据分析,系统可以设置布防和解除布防模式,在布防模式下,当检测到…

SSH配置公钥私钥免密登录——windows to linux

SSH配置公钥私钥免密登录——windows to linux SSH的安全机制一、修改远程主机ssh设置二、在windows客户端生成公钥私钥文件三、将客户端公钥追加到远程主机 .ssh/authorized_keys中参考链接 SSH的安全机制 SSH之所以能够保证安全,原因在于它采用了非对称加密技术(…

MATLAB 自定义生成圆柱点云(49)

MATLAB 自定义生成圆柱点云(49) 一、算法介绍二、具体实现1.代码2.效果一、算法介绍 按照一些提前指定的圆柱参数,自定义生成圆柱点云,可添加噪声,用于后续的实验测试 二、具体实现 1.代码 代码如下(示例): % 指定圆柱的参数 radius = 5; % 圆柱半径 height = 20…

【unity】如何汉化unity Hub

相信大家下载安装unity后看着满操作栏的英文,英文不好的小伙伴们会一头雾水。但是没关系你要记住你要怎么高速运转的机器进入中国,请记住我给出的原理,不懂不代表不会用啊。现在我们就来把编译器给进行汉化。 第一步:我们打开Uni…

Spring Boot | Spring Boot的“核心配置“与“注解“

目录: Spring Boot的核心配置与注解 :1. 全局配置文件 ( application.properties / application.yaml:创建项目时候自动生成,其会被“自动导入”到“程序”中 )application.properties配置文件application.yaml 配置文件 (推荐使用)当value值…

模板设计模式经典案例

模板设计模式讲究的是将不变的设置为基类,将变的设置为虚函数来让子类实现。下面就以这样的写下模板设计模式的例子。 例子场景 一个工程步骤分为step1,step2,其中step1由总工程指定,step2由子工程指定,最后由一个函数串起来&am…