MySQL Redo与Undo日志是什么


这篇文章主要介绍“MySQLRedo与Undo日志是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQLRedo与Undo日志是什么”文章能帮助大家解决问题。Redo日志是物理日志,记录的是页面的变化。提升数据库写入效率保证数据库不丢数据,进行数据恢复所谓REDO的组织方式,就是如何把需要的REDO内容记录到磁盘文件中,以方便高效的REDO写入,读取,恢复以及清理。我们这里把REDO从上到下分为三层:逻辑REDO层、物理REDO层和文件层。逻辑REDO层这一层是真正的REDO内容,顺序的数据流,REDO由多个不同Type的多个REDO记录收尾相连组成,有全局唯一的递增的偏移sn,InnoDB会在全局log_sys中维护当前sn的最大值,并在每次写入数据时将sn增加REDO内容长度。物理REDO层磁盘是块设备,InnoDB中也用Block的概念来读写数据,一个Block的长度OS_FILE_LOG_BLOCK_SIZE等于磁盘扇区的大小51免费云主机域名2B,每次IO读写的最小单位都是一个Block。文件层最终REDO会被写入到REDO日志文件中,并且日志文件是循环写入的用户线程的操作会首先写进log bufferlog buffer中的日志会顺序写入Redo逻辑日志中之后会落盘持久化存储到磁盘上之后通知用户已经存储完成了Checkpoint是Redo日志中脏页的标记位,有以下两个作用:维护Redo日志,方便清理减小重启的工作量数据库恢复流程:读取 checkpoint 信息•从 checkpoint 位置开始读取剩余日志解析日志并按 space_no 与 page_id 构建 hash 表应用 Redo 日志,Redo日志回放保证幂等性解析 binlog 构建 xid 列表扫描回滚段构建待提交事务列表回滚掉未在 xid 列表中的事务Undo log是逻辑日志,记录的是数据的增量变化,它的作用是保证事务的原子性和事务并发控制。可以用于事务回滚,以及提供多版本机制(MVCC),解决读写冲突和一致性读的问题。MVCC的意义:读写互不阻塞;降低死锁概率;实现一致性读。UndoLog在MVCC的作用:每个事务有一个单增的事务ID;数据页的行记录中包含了DB_ROW_ID,DB_TRX_ID,DB_ROLL_PTR;DB_ROLL_PTR将数据行的所有快照记录都通过链表的结构串联了起来。关于“MySQLRedo与Undo日志是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注百云主机行业资讯频道,小编每天都会为大家更新不同的知识点。

相关推荐: 怎么使用php代码实现图片旋转方向

这篇文章主要讲解了“怎么使用php代码实现图片旋转方向”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用php代码实现图片旋转方向”吧!php实现图片旋转方向的代码方法是:1、创建一个php示例文件;2、通…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

Like (0)
Donate 微信扫一扫 微信扫一扫
Previous 03/25 21:01
Next 03/25 21:01

相关推荐