MySQL锁系列(四)之 undo log

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: 什么是undo 1) redo 记录的是对页的重做日志,undo 记录的是对事务的逆向操作 2) undo 会产生redo,undo的产生也会伴随这redo的产生,因为重启恢复的时候,可以通过redo还原这些undo的操作,以达到回滚的目的 undo有什么用 1) 用于对事务的回滚 2)用于MVCC undo的存储结构 rollback segment * 在MySQL5.

什么是undo

1) redo 记录的是对页的重做日志,undo 记录的是对事务的逆向操作
2) undo 会产生redo,undo的产生也会伴随这redo的产生,因为重启恢复的时候,可以通过redo还原这些undo的操作,以达到回滚的目的

undo有什么用

1) 用于对事务的回滚
2)用于MVCC

undo的存储结构

  • rollback segment
* 在MySQL5.1的年代,一个MySQL实例,就只有一个rollback segment
* 在MySQL5.1+ 的年代,一个MySQL实例里面,可以有128个rollback segment
  • undo segment
* 一个segment 有 1024 个 undo slot,一个undo slot 对应一个undo log
* 一个事务(dml)对应一个undo log
  • 总结
据此推断:

1) 5.1 最多能够承载的并发事务(dml),1 * 1024 = 1024
2)5.1+ 最多能够承载的并发事务(dml),128 * 1024 = 10w左右

从此可以看出,5.1 之后的版本支持的并发写入事务数更多,性能更好

undo的格式

  • insert_undo
1) insert操作产生的undo
2)为什么要单独出来,因为insert的undo可以立马释放(不需要purge),不需要判断是否有其他事务引用,本来insert的事务也没有任何事务可以看见它嘛
  • update_undo
1)delete 或者 update 操作产生的undo日志
2)判断undo是否可以被删除,必须看这个undo上面是否被其他事务所引用
3) 如果没有任何事务引用,那么可以由后台线程purge掉这个undo
  • 如何判断undo日志是否有其他事务引用呢
1. 每一个undo log中都有一个DB_trx_id , 这个id记录的是该undo最近一次被更新的事务id
2. 如果这个id 不在readview(活跃事务列表) 里面,就可以认为没事务引用,即可删除?

undo存放在哪里

1) 5.6之前的版本,undo都是存放在ibdata,也就是所谓的共享表空间里面的
2) 5.6以及之后的版本,可以配置存放在单独的undo表空间中

什么是purge

1) delete语句操作的后,只会对其进行delete mark,这些被标记为删除的记录只能通过purge来进行物理的删除,但是并不回收空间
2)undo log,如果undo 没有任何事务再引用,那么也只能通过purge线程来进行物理的删除,但是并不回收空间

purge后空间就释放了吗

1) undo page里面可以存放多个undo log日志
2)只有当undo page里面的所有undo log日志都被purge掉之后,这个页的空间才可能被释放掉,否则这些undo page可以被重用

DML的相关物理实现算法

  • 主键索引
1. 对于delete   --需要undo绑定该记录才能进行回滚,所以只能打上标记,否则undo指向哪里呢

    delete mark

2. 对于update  --原记录可以物理删除,因为可以在新插入进来的地方进行undo绑定

    * 如果不能原地更新: delete(注意:这里是直接delete,而不是delete mark)  + insert
    * 如果可以原地更新,那么直接update就好
  • 二级索引
1. 对于delete  --不能直接被物理删除,因为二级索引没有undo,只能通过打标记,然后回滚。否则如果被物理删除,则无法回滚

    delete mark


2. 对于update  --不能直接被物理删除,因为二级索引没有undo,只能通过打标记,然后回滚。否则如果被物理删除,则无法回滚

    delete mark + insert
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
3天前
|
存储 算法 关系型数据库
MySQL事务与锁,看这一篇就够了!
MySQL事务与锁,看这一篇就够了!
|
6天前
|
关系型数据库 MySQL 数据管理
MySQL通过 bin-log 恢复从备份点到灾难点之间数据
MySQL通过 bin-log 恢复从备份点到灾难点之间数据
|
8天前
|
存储 关系型数据库 MySQL
MySQL的锁机制
MySQL的锁机制主要用于管理并发事务对数据的一致性和完整性的访问控制
25 4
|
12天前
|
DataWorks 关系型数据库 MySQL
DataWorks产品使用合集之在DataWorks中,如何通过PolarDB for MySQL来查看binlog日志
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
28 1
|
13天前
|
SQL 监控 关系型数据库
【MySQL学习】MySQL的慢查询日志和错误日志
【MySQL学习】MySQL的慢查询日志和错误日志
|
13天前
|
存储 SQL 关系型数据库
|
17天前
|
关系型数据库 MySQL 数据库
MySQL锁解密:读锁与写锁
【4月更文挑战第20天】
24 1
|
17天前
|
关系型数据库 MySQL 数据库
|
17天前
|
算法 关系型数据库 MySQL
|
17天前
|
SQL 关系型数据库 MySQL
MySQL锁:解析隐式锁与显式锁
【4月更文挑战第20天】
38 0