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

Mysql学习之事务日志undolog深入剖析

Undo log

redo log 是事务持久性的保证,undo log是事务原子性的保证。在事务中更新数据前置操作其实是要先写入一个undo log

如何理解undo 日志?
事务需要保证原子性,也就是事务中的操作要么全部完成,要么什么也不做。但有时候事务执行到一半会出现一些情况,比如:
情况1:事务执行过程中可能遇到各种错误,比如服务器本身的错误操作系统的错误、甚至是突然断电导致的错误。
情况2:程序员可以在事务执行过程中手动输入ROLLBACK语句结束当前事务的执行。
以上情况出现,需要把数据改回原来的样子,这个过程称之为回滚,这样就可以造成一个假象:这个事务看起来什么都没做,所以符合原子性要求。
在这里插入图片描述
undo log会产生redo log,也就是undo log的产生会伴随着redo log的产生,这是因为undo log也需要持久性的保护。

Undo日志的作用
作用1:回滚数据
在这里插入图片描述
作用2: MVCC
在这里插入图片描述
undo的存储结构
在这里插入图片描述
undo页的重用
在这里插入图片描述
在这里插入图片描述
回滚段中的数据分类
在这里插入图片描述
undo的类型
在这里插入图片描述
undo log的生命周期
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
undo log是如何回滚的
在这里插入图片描述
undo log的删除
在这里插入图片描述
purge线程两个主要作用是:清理undo页和清楚page里面带有Delete_Bit标识的数据行。在InnoDB中,事务中的Delete操作实际上并不是真正的删除掉数据行,而是一种Delete Mark操作,在记录上标识Delete_Bit,而不删除记录,是一种假删除,只是做了一个标记,真正的删除工作需要后台purge线程去完成。

小结
在这里插入图片描述

http://www.lryc.cn/news/306567.html

相关文章:

  • springboot整合druid及可能遇到的问题
  • c++文件的打开、读写和关闭。缓冲区的使用和控制。
  • 网络层的DDoS攻击与应用层的DDoS攻击之间的区别
  • Windows系统安全策略设置之本地NTLM重放提权
  • AI云增强升级!还原生动人像,拍出质感照片
  • PHP WebSocket:技术解析与实用指南
  • K8S实战:Centos7部署Kubernetes1.24.0集群
  • webpack的使用(中)
  • matlab经验模式分解的R波检测算法
  • win10编译openjdk源码
  • mysql 自定义函数create function
  • 【析】装卸一体化车辆路径问题的自适应并行遗传算法
  • react项目中的redux以及react-router-dom
  • django学习网址
  • @ 代码随想录算法训练营第4周(C语言)|Day21(二叉树)
  • Android的消息机制--Handler
  • 获取用户信息与token理解
  • 网络设备和网络软件
  • 全连接层是什么
  • JAVA工程师面试专题-《Redis》篇
  • JavaScript BOM
  • uniapp微信小程序-项目实战修改密码
  • linux系统---防火墙拓展
  • 就业的二三事
  • Go语言必知必会100问题-05 接口污染
  • FastBee商业版本源码获取下载
  • Java实战:Spring Boot集成Elasticsearch全文搜索引擎
  • python 进程笔记二(通讯) (概念+示例代码)
  • 电机控制-----电机极对数,相电感,相电阻以及磁链常数的测量
  • SQL注入之oracle注入+SQLbypass+sqlmap实战