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

MySQL 三大日志详解

在 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.kler.cn/a/407400.html

相关文章:

  • Java项目实战II基于微信小程序的新闻资讯平台(开发文档+数据库+源码)
  • 力扣--LCR 123.图书整理I
  • HTML+CSS网页模板,左侧导航,右侧内容,顶部LOGO
  • 【Spring Boot】Spring AOP中的环绕通知
  • 基于深度学习CNN算法的植物/中草药分类识别系统01--带数据集-pyqt5UI界面-全套源码
  • 算法(Algorithm)
  • 想做一个类似于东郊到家这样的预约上门小程序,app也行,这个现在好不好运营?
  • 基于python flask的网页五子棋实现,包括多种语言,可以悔棋、重新开始
  • 【Android】ARouter的使用及源码解析
  • centos和ubuntu有什么区别?
  • ASCB1系列APP操控末端回路智能微断 物联网断路器 远程控制开关 学校、工厂、农场、商业大楼等可用
  • LlamaIndex+本地部署InternLM实践
  • springboot配置https,并使用wss
  • manin动画编程(安装+入门)
  • 从零开始-VitePress 构建个人博客上传GitHub自动构建访问
  • go语言中的指针详解
  • 力扣第 61 题旋转链表
  • LeetCode题解:28.找出字符串中第一个匹配项的下标【Python题解超详细,滑动窗口法、内置 find 函数、KMP算法】,知识拓展, KMP算法
  • Java与Kotlin在鸿蒙中的地位
  • HAProxy面试题及参考答案(精选80道面试题)