Mysql的redoLog/undoLog

2023-10-19 16:59
文章标签 mysql database redolog undolog

本文主要是介绍Mysql的redoLog/undoLog,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.Redo日志—innodb存储引擎的日志文件

1.1RedoLog的作用

1.1.1

当发生数据修改的时候,innodb引擎会先将记录写到redo log中, 并更新内存,此时更新就算是完成了,同时innodb引擎会在合适 的时机将记录操作到磁盘中

1.1.2

Redolog是固定大小的,是循环写的过程 

1.1.3

有了redolog之后,innodb就可以保证即使数据库发生异常重启, 之前的记录也不会丢失,叫做crash-safe

1.2既然要避免io,为什么写redo log的时候不会造成io的问题? 

2.Undo log 

2.1作用

Undo Log是为了实现事务的原子性,在MySQL数据库InnoDB存储引擎中, 还用Undo Log来实现多版本并发控制(简称:MVCC)

▪ 在操作任何数据之前,首先将数据备份到一个地方(这个存储数据备份的地方 称为Undo Log)。然后进行数据的修改。如果出现了错误或者用户执行了 ROLLBACK语句,系统可以利用Undo Log中的备份将数据恢复到事务开始之 前的状态

2.2注意:undo log是逻辑日志,可以理解为:

– 当delete一条记录时,undo log中会记录一条对应的insert记录

– 当insert一条记录时,undo log中会记录一条对应的delete记录

– 当update一条记录时,它记录一条对应相反的update记录

3.binlog—服务端的日志文件

3.1Binlog是server层的日志,主要做mysql功能层面的事情

3.2与redo日志的区别:

1、redo是innodb独有的,binlog是所有引擎都可以使用的 

2、redo是物理日志,记录的是在某个数据页上做了什么修改,binlog是逻辑日志,记录的是这个语句的原始逻辑

3、redo是循环写的,空间会用完,binlog是可以追加写的,不会覆盖之前 的日志信息

3.3、Binlog中会记录所有的逻辑,并且采用追加写的方式

▪ 一般在企业中数据库会有备份系统,可以定期执行备份,备份的 周期可以自己设置

▪ 恢复数据的过程:

1、找到最近一次的全量备份数据 

2、从备份的时间点开始,将备份的binlog取出来,重放到要恢复的那个时刻

4.数据更新的流程

4.1执行流程:

1、执行器先从引擎中找到数据,如果在内存中直接返回,如果不在内存中,查询后返回

2、执行器拿到数据之后会先修改数据, 然后调用引擎接口重新吸入数据

3、引擎将数据更新到内存,同时写数据 到redo中,此时处于prepare阶段,并通 知执行器执行完成,随时可以操作

4、执行器生成这个操作的binlog

5、执行器调用引擎的事务提交接口,引擎把刚刚写完的redo改成commit状态, 更新完成 

5.Redo log的两阶段提交

先写redo log后写binlog:假设在redo log写完,binlog还没有写完的时候,MySQL进程 异常重启。由于我们前面说过的,redo log写完之后,系统即使崩溃,仍然能够把数据恢复 回来,所以恢复后这一行c的值是1。但是由于binlog没写完就crash了,这时候binlog里面 就没有记录这个语句。因此,之后备份日志的时候,存起来的binlog里面就没有这条语句。 然后你会发现,如果需要用这个binlog来恢复临时库的话,由于这个语句的binlog丢失,这 个临时库就会少了这一次更新,恢复出来的这一行c的值就是0,与原库的值不同。

▪ 先写binlog后写redo log:如果在binlog写完之后crash,由于redo log还没写,崩溃恢复 以后这个事务无效,所以这一行c的值是0。但是binlog里面已经记录了“把c从0改成1”这个 日志。所以,在之后用binlog来恢复的时候就多了一个事务出来,恢复出来的这一行c的值 就是1,与原库的值不同

这篇关于Mysql的redoLog/undoLog的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/241127

相关文章

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

浅谈mysql的not exists走不走索引

《浅谈mysql的notexists走不走索引》在MySQL中,​NOTEXISTS子句是否使用索引取决于子查询中关联字段是否建立了合适的索引,下面就来介绍一下mysql的notexists走不走索... 在mysql中,​NOT EXISTS子句是否使用索引取决于子查询中关联字段是否建立了合适的索引。以下

Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式

《Java通过驱动包(jar包)连接MySQL数据库的步骤总结及验证方式》本文详细介绍如何使用Java通过JDBC连接MySQL数据库,包括下载驱动、配置Eclipse环境、检测数据库连接等关键步骤,... 目录一、下载驱动包二、放jar包三、检测数据库连接JavaJava 如何使用 JDBC 连接 mys

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字