MySQL 三大日志详解

embedded/2024/11/23 9:30:14/

在 MySQL 数据库中,binlog(二进制日志)、redo log(重做日志)和 undo log(回滚日志)起着至关重要的作用。它们共同保障了数据库的高可用性、数据一致性和事务的可靠性。下面将对这三大日志进行详细的介绍。

一、binlog(二进制日志)

1. 定义与作用

Binlog 是 MySQL 数据库的二进制日志,它记录了数据库的所有变更操作,包括数据的插入、更新、删除等。主要作用有以下两点:

  • 主从复制:在主从复制架构中,主库将数据库的变更操作记录在 binlog 中,然后从库通过读取主库的 binlog 来实现数据同步。这样可以实现数据库的扩展和高可用性。
  • 数据恢复:如果数据库出现故障,可以通过备份的数据库文件和 binlog 来恢复到故障发生前的状态。

2. 特点

  • 逻辑日志:binlog 记录的是数据库的逻辑操作,例如 SQL 语句。这意味着它可以跨不同的数据库版本使用,因为它记录的是逻辑操作而不是物理操作。
  • 可配置性:可以通过配置参数来决定哪些数据库、哪些表的操作被记录在 binlog 中。还可以配置 binlog 的格式,如 STATEMENT(记录 SQL 语句)、ROW(记录行级变更)和 MIXED(混合模式)。
  • 可被多个从库读取:主库生成的 binlog 可以被多个从库同时读取,实现主从复制的扩展。

3. 工作原理

  • 数据库执行一个事务时,如果事务涉及到对数据的修改操作,MySQL 会将该事务的 SQL 语句记录到 binlog 中。
  • 主库将 binlog 发送给从库,从库通过读取 binlog 并执行其中的 SQL 语句来实现数据同步。

二、redo log(重做日志)

1. 定义与作用

Redo log 是 MySQL 数据库的重做日志,它记录了对数据页的物理修改操作。主要作用是保证事务的持久性,即当数据库发生故障时,通过 redo log 可以恢复未写入磁盘的数据。

2. 特点

  • 物理日志:redo log 记录的是对数据页的物理修改操作,例如某个数据页的某个偏移量处的值被修改为某个特定的值。
  • 循环写入:redo log 是循环写入的,当空间写满后,会从头开始覆盖旧的日志。为了防止覆盖未写入磁盘的数据,MySQL 会在覆盖旧日志之前将其写入磁盘。
  • 先写日志后写磁盘:在事务提交时,MySQL 会先将 redo log 写入磁盘,然后再将数据页写入磁盘。这样可以保证在数据库发生故障时,能够通过 redo log 恢复未写入磁盘的数据。

3. 工作原理

  • 当事务对数据进行修改时,MySQL 首先将修改操作记录在 redo log 中,并将数据页的修改标记为 “脏页”。
  • 后台有一个线程会定期将 “脏页” 写入磁盘。如果在写入磁盘之前数据库发生故障,那么在数据库重新启动时,可以通过 redo log 来恢复 “脏页” 中的数据。

三、undo log(回滚日志)

1. 定义与作用

Undo log 是 MySQL 数据库的回滚日志,它记录了事务对数据的反向操作,用于撤销事务的修改。主要作用有以下两点:

  • 事务回滚:如果事务执行过程中出现错误,可以通过 undo log 来撤销事务对数据的修改,实现事务的回滚。
  • MVCC(多版本并发控制):为了实现 MVCC,MySQL 需要保存数据的多个版本。undo log 中记录了数据的旧版本,通过它可以实现数据的多版本并发控制。

2. 特点

  • 逻辑日志:undo log 记录的是事务对数据的反向操作,是逻辑日志。
  • 与事务相关:每个事务都有自己的 undo log,用于回滚该事务对数据的修改。
  • 可用于 MVCC:undo log 中的旧版本数据可以用于实现 MVCC,提高数据库的并发性能。

3. 工作原理

  • 当事务对数据进行修改时,MySQL 会同时在 undo log 中记录反向操作。
  • 如果事务需要回滚,MySQL 可以通过 undo log 中的反向操作来撤销事务对数据的修改。
  • 在 MVCC 中,当一个事务读取数据时,MySQL 会根据事务的隔离级别和当前数据的版本,从 undo log 中找到合适的版本返回给事务。

四、三大日志的关系

Binlog、redo log 和 undo log 在 MySQL 数据库中相互配合,共同保障了数据库的高可用性和数据一致性。它们之间的关系如下:

  • binlog 与 redo log 的关系:binlog 是逻辑日志,记录的是数据库的逻辑操作;redo log 是物理日志,记录的是对数据页的物理修改操作。在主从复制中,主库将 binlog 发送给从库,从库通过执行 binlog 中的 SQL 语句来实现数据同步。而在事务提交时,MySQL 会先将 redo log 写入磁盘,然后再将 binlog 写入磁盘,这样可以保证在数据库发生故障时,能够通过 redo log 恢复未写入磁盘的数据,同时也可以通过 binlog 进行数据恢复和主从复制。
  • redo log 与 undo log 的关系:redo log 用于保证事务的持久性,undo log 用于事务回滚和 MVCC。当事务对数据进行修改时,MySQL 会同时将修改操作记录在 redo log 和 undo log 中。如果事务需要回滚,MySQL 可以通过 undo log 中的反向操作来撤销事务对数据的修改;如果数据库发生故障,MySQL 可以通过 redo log 来恢复未写入磁盘的数据。
  • binlog、redo log 和 undo log 的整体关系:这三种日志在 MySQL 数据库中共同作用,保证了数据库的高可用性、数据一致性和事务的可靠性。binlog 用于主从复制和数据恢复,redo log 用于保证事务的持久性,undo log 用于事务回滚和 MVCC。它们相互配合,使得 MySQL 数据库能够在各种情况下保持数据的完整性和一致性。

http://www.ppmy.cn/embedded/139819.html

相关文章

[CISCN 2019初赛]Love Math 详细题解

知识点: 数学函数转换字符串 GET传参外部赋值 eval()函数解析执行命令 PHP动态调用函数名 源码: <?php error_reporting(0); //听说你很喜欢数学,不知道你是否爱它胜过爱flag if(!isset($_GET[c])){show_source(__FILE__); }else{//例子 c20-1$content $_GET[c];if (…

第十章Javascript的应用

10.1 JavaScript概述 10.1.1 JavaScript简介 JavaScript是一种基于对象(0bject)和事件驱动(Event Driven)并具有安全性能的脚本语言&#xff0c;能够与HTML(超文本标记语言)、Java语言一起在Web页面中与Web客户交互它无须经过先将数据传给服务器端(Server)、再传回来的过程&…

使用TensorFlow实现简化版 GoogLeNet 模型进行 MNIST 图像分类

在本文中&#xff0c;我们将使用 TensorFlow 和 Keras 实现一个简化版的 GoogLeNet 模型来进行 MNIST 数据集的手写数字分类任务。GoogLeNet 采用了 Inception 模块&#xff0c;这使得它在处理图像数据时能更高效地提取特征。本教程将详细介绍如何在 MNIST 数据集上训练和测试这…

redis工程实战介绍(含面试题)

文章目录 redis单线程VS多线程面试题**redis是多线程还是单线程,为什么是单线程****聊聊redis的多线程特性和IO多路复用****io多路复用模型****redis如此快的原因** BigKey大批量插入数据测试数据key面试题海量数据里查询某一固定前缀的key如果生产上限值keys * &#xff0c;fl…

egrep grep 区别

‌egrep 和 grep 的主要区别在于对正则表达式的支持。 -rwxr-xr-x 1 root root 28 Jan 29 2020 /bin/egrep -rwxr-xr-x 1 root root 199136 Jan 29 2020 /bin/grep 1e6ebb9dd094f774478f72727bdba0f5 /bin/grep ef55d1537377114cc24cdc398fbdd930 /bin/egrep 区别 gre…

js中new操作符具体都干了什么?

在JavaScript中&#xff0c;new操作符是一个用于创建对象实例的关键字&#xff0c;它背后的机制相当复杂&#xff0c;但以下是它执行的主要步骤&#xff1a; new操作符的工作原理&#xff1a; 创建一个全新的空对象&#xff1a;首先&#xff0c;JavaScript会创建一个全新的对象…

vue3 + elementPlus 日期时间选择器禁用未来及过去时间

<el-date-pickerv-model"form.jyTime"type"datetime"placeholder"请选择加油时间"format"YYYY/MM/DD HH:mm:ss"value-format"YYYY-MM-DD HH:mm:ss":disabled-date"disabledDate"/> 一、禁用未来时间 /** 时…

基础自动化系统的任务

基础自动化系统的任务主要包括实现自动控制、提高生产效率、减少人工干预等。以下是其具体任务的相关介绍&#xff1a; 实现自动控制 控制机器设备&#xff1a;基础自动化系统通过预设的程序和逻辑规则&#xff0c;对机器或设备进行自动控制和运行。执行特定任务&#xff1a;这…