我的编程空间,编程开发者的网络收藏夹
学习永远不晚

InnoDB undo tablespace使用及原理

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

InnoDB undo tablespace使用及原理

前言

Undo log是InnoDB MVCC事务特性的重要组成部分,对记录做了变更操作时会产生undo记录,默认存储到系统表空间中,但是从5.6开始,可以使用独立的undo表空间。

Undo记录存储的是老版本数据,当一个旧事务需要读取数据时,为了能读取到老版本数据,需要顺着undo连找到满足其可见性的记录。当版本链很长时,可以认为这是要一个比较耗时的操作。

大多数对记录的变更insert、update、delete。Insert操作在事务提交前只对当前事务可见,因此产生的undo日志可以在事务提交后直接删除(没有对刚插入的数据有可见性需求),而对于update、delete则需要维护多版本信息。

Undo tablespace

MySQL5.6可以使用独立undo表空间。innodb_undo_tablespaces:0-126,在系统初始化后该文件大小默认是10M。虽然可以将其从系统表空间提出了,使系统表空间不再因为大事务而迅速不断增大,但是独立出来的undo表空间仍然比较鸡肋,不能truncate。而且也没有相关undo表空间文件大小的阈值。

MySQL5.7.5之后undo表空间可以truncate了。需要配置至少2个undo表空间innodb_undo_spaces=2,undo表空间被删除时临时设置为offline状态,至少有另外一个undo表空间服务才可以让server工作。如果配置成1个undo表空间的话,即使开启truncate也没用,本undo表空间文件会一直增大,甚至撑爆磁盘。

Mysql5.7.5之后版本,set global innodb_undo_log_truncate=on开启truncate功能,innodb_max_undo_log_size为undo表空间文件的阈值,默认1G,超过改值,会自动进行truncate。如果不开启truncate则导致undo表空间文件不断增大。

被选中删除的undo文件,对应的回滚段标记为inactive,purge回收不再使用的回滚段,完成后进行truncate,恢复到10M大小,回滚段再次标记为active。

innodb_undo_logs定义了InnoDB使用的回滚段个数,必须设置35个以上;第一个常驻系统表空间,若使用独立undo表空间,则第一个置为inactive。回滚段2-33在共享临时表空间ibtmp1。34th 35th分别是独立表空间的第一个和第二个。

undo tablesapce和回滚段之间什么关系

InnoDB undo tablespace使用及原理

可以看到在系统启动的时候创建好undo表空间。默认undo表空间放到系统表空间里面。当将undo表空间独立出来时,undo表空间轮流分给各个回滚段。

InnoDB undo tablespace使用及原理
可以看到当undo表空间提出了的时候,回滚段是轮询分配给每个事务的,并且不使用系统表空间,保证所有的undo log都存储到undo 独立表空间中。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

InnoDB undo tablespace使用及原理

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MyISAM 和 InnoDB 索引结构及其实现原理

数据库索引,是数据库管理系统中一个排序的数据结构,以协助快速查询、更新数据库表中数据。索引的实现通常使用B_TREE。B_TREE索引加速了数据访问,因为存储引擎不会再去扫描整张表得到需要的数据;相反,它从根节点开始,根节点保存了子节点的指针,存储引擎会根据指
MyISAM 和 InnoDB 索引结构及其实现原理
2016-02-15

MySQL InnoDB锁类型及锁原理实例解析

目录锁共享锁排他锁意向锁记录锁间隙锁临键锁死锁死锁产生条件行锁发生死锁表锁发生死锁锁的释放事务阻塞死锁的避免锁的日志行锁的原理不带任何索引的表带主键索引的表带唯一索引的表结论1.表必定有索引2.唯一索引数据行加锁,主键索引同样被锁锁锁是用
2022-11-27

Gosingleflight使用以及原理

singleflight官方解释其为:singleflight提供了一个重复的函数调用抑制机制。通俗的解释其作用是,若有多个协程运行某函数时,只让一个协程去处理,然后批量返回。非常适合来做并发控制。常见用于缓存穿透的情况
2023-01-02

MyBatis 动态SQL使用及原理

这篇文章主要为大家介绍了MyBatis动态SQL使用及原理的学习详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-05-20

nohup的原理及怎么使用

本篇内容主要讲解“nohup的原理及怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“nohup的原理及怎么使用”吧!nohup 命令运行由 Command参数和任何相关的 Arg参数指定的
2023-06-28

MVC+proxy的原理及使用方法

这篇文章主要讲解了“MVC+proxy的原理及使用方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MVC+proxy的原理及使用方法”吧!目录1、创建业务层UserService接口定义需
2023-06-20

Android HandlerThread的使用及原理详解

一、HandlerThread的含义HandlerThread能够新建拥有Looper的线程。这个Looper能够用来新建其他的Handler。(线程中的Looper)需要注意的是,新建的时候需要被回调。 二、HandlerThread的用
2022-06-06

编程热搜

目录