二进制日志备份与恢复

二进制备份是 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结束

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【PLC】PROFIBUS(二):总线协议DP、PA、FMS

1、总线访问协议 (FDL) 1.1、多主通信 多个主设备间,使用逻辑令牌环依次向从设备发送命令。 特征: 主站间使用逻辑令牌环、主从站间使用主从协议主站在一个限定时间内 (Token Hold Time) 对总线有控制权从站只是响应一个主站的请求它们对总线没有控制…

spring-boot-devtools配置和原理

一、前言 昨天,一个同事Eclipse在启动SpringBoot项目时一直不停地加载,后来发现是因为spring-boot-devtools造成的问题,因为我们把日志输出的目录设置在当前项目里(~/mnt/logs/,这样设置是因为mac电脑没有根目录权限&…

Django之Web应用架构模式

一、Web应用架构模式 在开发Web应用中,有两种模式 1.1、前后端不分离 在前后端不分离的应用模式中,前端页面看到的效果都是由后端控制,由后端渲染页面或重定向,也就是后端需要控制前端的展示。前端与后端的耦合度很高 1.2、前后端分离 在前后端分离的应用模式中,后端仅返…

树状数组的三种代码模板

下标从一开始。 所有奇数等于本身,偶数/2等于所在层数。 二进制末尾有几个0就在第几层。 每一个树状数组中表示的都是这么一个区间的和,左开右闭。 写成lowbit(x),返回的就是2^k,k就是末尾有几个0。 这是求和代码 单点修改 这是…

案例 | 华院计算x第一财经:我和我的数智人唱双簧

创新关乎命运,科技引领未来。生成式人工智能(AIGC)给传媒行业发展带来严峻挑战的同时,也带来千载难逢的重大发展机遇。2024年政府工作报告中提出,要深化大数据、人工智能等研发应用,开展“人工智能”行动,打造具有国际…

龙泉寺扫地僧:十年坚持打造轻量级浏览器内核

王斌,网名龙泉寺扫地僧。作为一个独立开发者,他专注于浏览器内核研究十余年。他主要从事 MiniBlink 项目的工作,旨在创建一个精简且高效的浏览器内核,应对 Chromium 庞大的体积和内存占用问题。 龙泉寺扫地僧在谈及做 MiniBlink 的…

10个你必须知道的浏览器指纹检测工具,保护你的隐私安全

在当前的数字时代,个人隐私保护变得越来越重要,特别是对于互联网用户来说。有一种叫做“浏览器指纹”的技术,它能悄悄收集我们使用的浏览器和设备的各种细节信息。这本是为提供个性化服务,但对那些需要在不同平台同时管理多个账号…

11.数据库技术(下)

1.select语句 中括号表示可有可无; 尖括号表示变量名; 分组后再筛选,用having;分组前筛选,用where; select后跟随的所有列,除聚集函数外,都需要列在group by后; 注&…

【比特币】比特币的奥秘、禁令的深层逻辑与风云变幻

导语: 比特币(Bitcoin),这个充满神秘色彩的数字货币,自诞生以来便成为各界瞩目的焦点。它背后所蕴含的Mining机制、禁令背后的深层逻辑以及市场的风云变幻,都让人欲罢不能。今天,我们将深入挖掘比特币的每一个角落&…

HarmonyOS应用/元服务发布流程

在发布HarmonyOS应用/元服务前,建议您在本地进行调试,以查看和验证应用/元服务运行效果,减少发布过程中可能遇到的问题。 华为支持您使用HUAWEI DevEco Studio自动化签名的方式对应用/元服务进行调试,总体流程如下。 配置签名信息…

蓝桥杯练习系统(算法训练)ALGO-967 共线

资源限制 内存限制:256.0MB C/C时间限制:1.0s Java时间限制:3.0s Python时间限制:5.0s 问题描述 给定2维平面上n个整点的坐标,一条直线最多能过几个点? 输入格式 第一行一个整数n表示点的个数   …

c语言--跳出continue、break

C 语言中的 continue 语句有点像 break 语句。但它不是强制终止,continue 会跳过当前循环中的代码,强迫开始下一次循环。 对于 for 循环,continue 语句执行后自增语句仍然会执行。对于 while 和 do…while 循环,continue 语句重新…

CI860K01 3BSE032444R1 参数说明书

ABB CI860K01 3BSE032444R1是一款ABB公司生产的通信接口模块。 这款模块是专为工业自动化环境设计的,能够在各种设备之间提供稳定和可靠的数据传输接口。它采用了先进的通信技术和严格的生产工艺,确保了产品的高质量和性能。此外,它的设计合…

antdp | 菜单展示-菜单路由配置

扩展的路由配置 Layout 插件会基于 umi 的路由,封装了更多的配置项,支持更多配置式的能力。新增: 侧边栏菜单配置布局路由级别展示 / 隐藏相关配置与权限插件结合,配置式实现权限路由的功能 示例如下: //config/rou…

抗干扰段码屏驱动芯片/ LCD液晶屏驱动/仪器仪表液晶驱动IC-VK1C21D/DA FAE支持

产品型号:VK1C21D/DA 产品品牌:永嘉微电/VINKA 封装形式:SOP28/SSOP28 可定制裸片:DICE(COB邦定片);COG(邦定玻璃用) 工程服务,技术支持! 概述: VK1C21D/DA是一个点阵式存储映射…

PTA金字塔游戏

幼儿园里真热闹,老师带着孩子们做一个名叫金字塔的游戏,游戏规则如下: 首先,老师把孩子们按身高从高到矮排列,选出最高的做队长,当金字塔的塔顶,之后在其余小朋友里选出两个最高的,…

【基于HTML5的网页设计及应用】——当前日期

🎃个人专栏: 🐬 算法设计与分析:算法设计与分析_IT闫的博客-CSDN博客 🐳Java基础:Java基础_IT闫的博客-CSDN博客 🐋c语言:c语言_IT闫的博客-CSDN博客 🐟MySQL&#xff1a…

串口IAP介绍

一、STM32编程方式 (1)在线编程(ICP,in circuit programming) 系统存储器:留给ST写启动程序代码,启动程序代码通过串口1接口实现对闪存存储器的编程。 (2)在程序中编程…

Python接口自动化pytest框架安装

1、创建一个requirements.txt文件夹 2、输入内容:如下图 pytest pytest-html pytest-xdist pytest-ordering pytest-rerunfailures pytest-base-url allure-pytest3、在terminal中输入安装命令:pip install -r requirements.txt 安装成功 4、在termina…

飞书很好,但赢不了,只能裁员

心碎飞书 3 月 26 日,字节跳动旗下产品飞书的 CEO 谢欣发布全员信,正式宣布进行新一轮的组织调整,即裁员。 内部全员信如下: 我有不少朋友是在字节跳动,甚至就在 Lark 的。 同时我也因为会经常和一些平台的运营小伙伴有…