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

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 数据库能够在各种情况下保持数据的完整性和一致性。

相关文章:

MySQL 三大日志详解

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

Java 岗面试八股文及答案整理(2024最新版)

春招,秋招,社招,我们 Java 程序员的面试之路,是挺难的,过了 HR,还得被技术面,小刀在去各个厂面试的时候,经常是通宵睡不着觉,头发都脱了一大把,还好最终侥幸能…...

Web3.0安全开发实践:Clarity最佳实践总结

在过去的一段时间里,CertiK团队对比特币生态系统及其发展进行了深入研究。同时,团队还审计了多个比特币项目以及基于不同编程语言的智能合约,包括OKX的BRC-20钱包和MVC DAO的sCrypt智能合约实现。 现在,我们的研究重点转向了Clar…...

基于Springboot+Vue动漫推荐平台管理系统(源码+lw+讲解部署+PPT)

前言 详细视频演示 论文参考 系统介绍 系统概述 核心功能 用户角色与功能 具体实现截图 1. 热门动漫功能 2. 文章专栏功能 3. 会员分享功能 4. 热门动漫管理功能(管理员端) 5. 动漫分类管理功能 技术栈 后端框架SpringBoot 前端框架Vue …...

秋意浓,森林披金装

秋意浓,森林披金装, 枫叶如火,漫山遍野狂。 松间轻风送寒意, 鸟鸣悠扬入云翔。 林间小径蜿蜒行, 落叶铺成金色毯。 溪水潺潺绕石转, 映出天边一抹霞。 野菊点缀在草间, 白云悠悠随意闲。…...

Chrome离线安装包下载

1、问Chrome的官网:https://www.google.cn/chrome/ 直接下载的是在线安装包,安装需要联网。 2、如果需要在无法联网的设备上安装Chrome,需要在上面的地址后面加上?standalone1。 Chrome离线安装包下载地址:https://www.google.c…...

安卓手机5G网络频繁掉4G 问题解决 手机5G网络优化方案

问题环境 在某个长期停留的位置(例如:躺平)使用手机时网络突然从5G跳到4G,偶尔跳来跳去导致网络体验很差,经过调整5G网络情况下网速及其他体验都要更好,基于这样的情况使用一种简单的操作,锁定5…...

使用LLaMA-Factory微调时的问题与解决方案记录

文章目录 如何指定微调使用的显卡如何解决显卡通信导致的报错模型微调的实际epoch和step如何计算如何实现多卡全量微调模型微调后的结果如何查看模型测试后的指标如何理解如何指定微调使用的显卡 启动网页时使用这种执行命令 CUDA_VISIBLE_DEVICES=5,6,7 llamafactory-cli we…...

Go语言switch语句

在Go语言中,switch,是一个高度灵活,其功能强大的控制结构,相比较Java中的switch,更受到语言重视。 目录 1.基础用法2.多值匹配3.不指定表达式的 switch4.使用 fallthrough 强制进入下一个分支5.使用类型断言的 switch…...

JavaScript DOM使用

DOM Document Object Model 简单而言,就是JavaScript将HTML文档的各个组成部分封装为对象。 封装的对象分别为: Document:整个HTML的文档对象 Element:元素对象(也就是HTML中的标签) Attribute:…...

人工智能|计算机视觉——微表情识别(Micro expression recognition)的研究现状

一、简述 微表情是一种特殊的面部表情,与普通的表情相比,微表情主要有以下特点: 持续时间短,通常只有1/25s~1/3s;动作强度低,难以察觉;在无意识状态下产生,通常难以掩饰或伪装;对微表情的分析通常需要在视频中,而普通表情在图像中就可以分析。由于微表情在无意识状态…...

耿恭坚守城池的方法

疏勒城之战中,耿恭坚守城池的方法主要有以下几点: 选择有利地势:耿恭深知疏勒城依山傍水、地势险要,易守难攻,于是果断放弃金满城,移师至疏勒城据守,为长期坚守创造了良好的地理条件.运用心理战…...

小兔鲜项目总结——项目亮点

目录 1、基于业务的逻辑组件拆分思想2、长页面吸顶交互的实现3、自定义图片懒加载指令并封装为插件4、画板插槽组件等业务通用组件封装5、通用逻辑函数的封装6、列表无限加载7、路由缓存问题的处理 小兔鲜项目其实在暑假之前就已经做完了,但是一直没有空做总结&…...

Cesium的ClearCommand的流程

ClearCommand是在每帧渲染前可以将显存的一些状态置为初始值,就如同把擦黑板。当然也包括在绘制过程中擦掉部分的数据,就如同画家在开始绘制的时候会画导览线(如透视线),轮廓出来后这些导览线就会被擦除。 我画了一个…...

Fakelocation Server服务器/专业版 ubuntu

前言:需要Ubuntu系统 Fakelocation开源文件系统需求 Ubuntu | Fakelocation | 任务一 任务一 更新Ubuntu(安装下载不再赘述) sudo -i # 提权 sudo apt update # 更新软件包列表 sudo apt upgrade # 升级已安装的软…...

Spring AI Alibaba 快速入门

Spring AI Alibaba 实现了与阿里云通义模型的完整适配,接下来,我们将学习如何使用 spring ai alibaba 开发一个基于通义模型服务的智能聊天应用。 一、快速体验示例 注意:因为 Spring AI Alibaba 基于 Spring Boot 3.x 开发,因此…...

Docker Registry(镜像仓库)详解

Docker Registry(镜像仓库)详解 Docker Registry,即Docker镜像仓库,是Docker生态系统中一个至关重要的组件。它负责存储、管理和分发Docker镜像,为Docker容器提供镜像资源。本文将深入探讨Docker Registry的功能、结构…...

RTOS学习笔记---“二值信号量”和“互斥信号量”

在实时操作系统(RTOS)中,“二值信号量”和“互斥信号量”是两种常见的同步机制,用于线程之间的协调与资源管理。尽管它们有相似之处,都基于信号量概念,但它们的用途和行为存在重要区别。 1. 二值信号量&…...

Oracle-物化视图基本操作

-- 物化视图 -- 与普通视图的区别:真实存在数据的 普通视图的数据在基表 物化视图看成是, 一个定时运行的计算JOB一个存计算结果的表 创建时生成数据: 分为两种:build immediate 和 build deferred, build immediate是在创…...

(功能测试)测试报告

其中的统计分析和测试结果确认是必须要有的; 测试过程回顾:测试的时间和阶段,是否出现延期,与预期的任务计划是否匹配; !统计分析:统计写多少用例,用例覆盖情况如何(100%…...

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…...

51c自动驾驶~合集58

我自己的原文哦~ https://blog.51cto.com/whaosoft/13967107 #CCA-Attention 全局池化局部保留,CCA-Attention为LLM长文本建模带来突破性进展 琶洲实验室、华南理工大学联合推出关键上下文感知注意力机制(CCA-Attention),…...

C++.OpenGL (10/64)基础光照(Basic Lighting)

基础光照(Basic Lighting) 冯氏光照模型(Phong Lighting Model) #mermaid-svg-GLdskXwWINxNGHso {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-GLdskXwWINxNGHso .error-icon{fill:#552222;}#mermaid-svg-GLd…...

Android第十三次面试总结(四大 组件基础)

Activity生命周期和四大启动模式详解 一、Activity 生命周期 Activity 的生命周期由一系列回调方法组成,用于管理其创建、可见性、焦点和销毁过程。以下是核心方法及其调用时机: ​onCreate()​​ ​调用时机​:Activity 首次创建时调用。​…...

并发编程 - go版

1.并发编程基础概念 进程和线程 A. 进程是程序在操作系统中的一次执行过程,系统进行资源分配和调度的一个独立单位。B. 线程是进程的一个执行实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位。C.一个进程可以创建和撤销多个线程;同一个进程中…...

MinIO Docker 部署:仅开放一个端口

MinIO Docker 部署:仅开放一个端口 在实际的服务器部署中,出于安全和管理的考虑,我们可能只能开放一个端口。MinIO 是一个高性能的对象存储服务,支持 Docker 部署,但默认情况下它需要两个端口:一个是 API 端口(用于存储和访问数据),另一个是控制台端口(用于管理界面…...

Unity UGUI Button事件流程

场景结构 测试代码 public class TestBtn : MonoBehaviour {void Start(){var btn GetComponent<Button>();btn.onClick.AddListener(OnClick);}private void OnClick(){Debug.Log("666");}}当添加事件时 // 实例化一个ButtonClickedEvent的事件 [Formerl…...

从面试角度回答Android中ContentProvider启动原理

Android中ContentProvider原理的面试角度解析&#xff0c;分为​​已启动​​和​​未启动​​两种场景&#xff1a; 一、ContentProvider已启动的情况 1. ​​核心流程​​ ​​触发条件​​&#xff1a;当其他组件&#xff08;如Activity、Service&#xff09;通过ContentR…...

全面解析数据库:从基础概念到前沿应用​

在数字化时代&#xff0c;数据已成为企业和社会发展的核心资产&#xff0c;而数据库作为存储、管理和处理数据的关键工具&#xff0c;在各个领域发挥着举足轻重的作用。从电商平台的商品信息管理&#xff0c;到社交网络的用户数据存储&#xff0c;再到金融行业的交易记录处理&a…...

基于Uniapp的HarmonyOS 5.0体育应用开发攻略

一、技术架构设计 1.混合开发框架选型 &#xff08;1&#xff09;使用Uniapp 3.8版本支持ArkTS编译 &#xff08;2&#xff09;通过uni-harmony插件调用原生能力 &#xff08;3&#xff09;分层架构设计&#xff1a; graph TDA[UI层] -->|Vue语法| B(Uniapp框架)B --&g…...