14.3 InnoDB Multi-Versioning InnoDB 多版本

InnoDB 是一个多版本的存储引擎,它保持信息关于改变的数据老版本的信息,

为了支持事务功能比如并发和回滚。

这些信息是存储在表空间在称为一个rollback segment(Oracle类似的数据结构).

InnoDB 使用信息在回滚段来执行undo 操作在事务回滚时。

它也使用信息来创建记录的早期版本用于一个一致性读

内部的, InnoDB 增加3个字段到每个存储的行在数据库里.

一个6字节的DB_TRX_ID字段表明事务标识用于最好的事务插入或者更新记录。

此外, 一个删除是内部对待为一个update 一个指定的bit在记录内是被设置标记为删除。

每个记录包含一个7字节的DB_ROLL_PTR  字段称为  roll pointer. 

回滚指针指向一个undo 日志记录 写到回滚段。

如果记录被更新,undo log 记录包含需要的信息来创建它被更新前记录的内容。

一个6字节的DB_ROW_ID 字段包含一个row ID 单调增加作为新的记录被插入。

如果InnoDB自动生成一个聚合索引,index 包含row ID 值。 否则, DB_ROW_ID 列不出现在任何索引里

Undo logs 在回滚段是被分成insert和update undo logs.

Insert undo logs 是只有在事务回滚时需要,并且可以在事务提交时丢弃。

Update undo logs 是用于一致性读,

但是它们只有在目前没有事务 InnoDB已经分配一个快照在一致性读需要信息在update undo log 来创建一个

定期的提交你的事务,包含那些事务用于一致性读。

否则, InnoDB 不能丢弃数据从update undo logs, rollback segment 会变的很大,填满你的表空间

一个undo log 在回滚段的物理大小是典型的小于相应的插入或者更新的记录。

你可以使用这个信息来计算你的回滚段需要的空间

在InnoDB 多版本策略中,一个记录不是物理删除的从数据库中 当你删除它使用SQL语句。

InnoDB 只是物理的移动相应的记录和它的索引记录 当它丢弃update undo log 记录update undo log 记录。

这个称谓一个purge, 它是非常快的

如果你插入和删除记录以小的匹配以同样的速率, 清除线程可以开始滞后,表的记录会变的越来越大 

因为所有的"dead"记录.

多版本和次要索引:

InnoDB 多版本并发控制(MVCC) 对待seconady indexes 不同于clustered indexes.

记录在一个 clustered index 是原地更新, 它们隐含的系统列指向undo log entries 从记录的早期版本被重构。

不像clustered index records, 

secondary index records 不包含隐藏的系统列 也不是原地更新

当一个secondary index 列被更新, 老的secondary index records是标记为删除,

新的记录被插入, 标记的记录最终被清理。

当一个 secondary index record  是标记为删除或者 secondary index page 是被一个新的事务更新,

InnoDB 查询数据库记录在 clustered index.

在 clustered index,记录的DB_TRX_ID 是被检查,当前记录的版本是从undo log 检索

如果记录是被修改 在读取事务初始化后

如果一个 secondary index record 是标记为删除或者 secondary index page被一个新的事务更新,

覆盖索引技术就不能使用。

14.3 InnoDB Multi-Versioning InnoDB 多版本的更多相关文章

  1. 14.1.3 Turning Off InnoDB 关掉InnoDB

    14.1.3 Turning Off InnoDB 关掉InnoDB: Oracle 推荐InnoDB 作为首选的存储引擎用于典型的数据库应用,从单用户的wikis到博客, 到高端应用把性能推到极限. ...

  2. 14.6.1 Creating InnoDB Tables 创建InnoDB 表:

    14.6.1 Creating InnoDB Tables 创建InnoDB 表: 创建一个InnoDB 表,使用CREATE TABLE 语句,你不需要指定 ENGINE=InnoDB子句 如果In ...

  3. 14.8.1 Creating InnoDB Tables 创建InnoDB 表

    14.8.1 Creating InnoDB Tables 创建InnoDB 表 创建一个InnoDB表,使用CREATE TABLE 语句,你不需要指定ENGINE=InnoDB 子句 如果Inno ...

  4. 14.7.1 Resizing the InnoDB System Tablespace InnoDB 系统表空间大小

    14.7.1 Resizing the InnoDB System Tablespace InnoDB 系统表空间大小 这个章节描述如何增加或者减少 InnoDB 系统表空间的大小 增加InnoDB ...

  5. 14.6.8 Configuring the InnoDB Master Thread IO Rate 配置InnoDB 主线程IO 速率:

    14.6.8 Configuring the InnoDB Master Thread IO Rate 配置InnoDB 主线程IO 速率: 主线程 在InnoDB 是一个线程 执行各种任务在后台. ...

  6. 14.6.3.5 Configuring InnoDB Buffer Pool Flushing

    14.6.3.5 Configuring InnoDB Buffer Pool Flushing InnoDB 执行某些任务在后台, 包括脏叶的刷新(那些已经发生改变的pages 但是没有写入到数据文 ...

  7. 14.6.3.4 Configuring InnoDB Buffer Pool Prefetching (Read-Ahead) 配置InnoDB Buffer pool 预取

    14.6.3.4 Configuring InnoDB Buffer Pool Prefetching (Read-Ahead) 配置InnoDB Buffer pool 预取 一个预读请求是一个I/ ...

  8. 14.6.3.1 The InnoDB Buffer Pool

    14.6.3.1 The InnoDB Buffer Pool InnoDB 保持一个存储区域被称为buffer pool 用于cache数据和索引在内存里, 知道InnoDB buffer pool ...

  9. 14.5.5.1 An InnoDB Deadlock Example 一个InnoDB 死锁实例

    14.5.5.1 An InnoDB Deadlock Example 一个InnoDB 死锁实例 下面的例子演示了一个错误可以发生当一个lock 请求会导致一个死锁,例子设计2个客户端,A和B: J ...

  10. 14.5.5 Deadlocks in InnoDB

    14.5.5 Deadlocks in InnoDB 14.5.5.1 An InnoDB Deadlock Example 14.5.5.2 Deadlock Detection and Rollb ...

随机推荐

  1. JAX-WS + Spring 开发webservice

    通过几天的时间研究了下使用jax-ws来开发webservice,看了网上的一些资料总结出jax-ws的开发大概分为两种. 以下项目使用的spring3.0,jar包可以到官网下载 第一种:使用独立的 ...

  2. hash定义

    * 若结构中存在关键字和K相等的记录,则必定存储在f(K)的位置上.由此,不需比较便可直接取得所查记录.这个对应关系f称为 散列函数(Hash function),按这个思想建立的表为 散列表. * ...

  3. PermGen space错误解决方法

    在看下文之前,首先要确认意见事情,就是你是怎样启动tomcat的,我们在平时的开发环境其中,都是通过startup.bat方式启动tomcat的,那么你依照以下的方式,去改动/bin/catalina ...

  4. [转] C++指针加整数、两个指针相减的问题

    http://blog.csdn.net/onlyou930/article/details/6725051 说来惭愧,写C++有一段时间了.这个问题从来没有认真考虑过,此次标记于此: 考虑如下问题: ...

  5. Android AppWidget(转)

    AppWidget不知道大家使用这个多不多,这个在手机上也叫做挂件,挂件也就是放在桌面方便用户进行使用的,从android1.6开始挂件支持一些简单的lauout和view,到了android4.0之 ...

  6. LeanCloud使用入门(android)

    LeanCloud算是一个简单易用的云服务器,其中包含了强大的数据库支持,我们只需要将此服务器应用到本地的代码即可实现后台的存储与交互. 那么,如何简单实现本地代码和LeanCloud服务器的交互呢? ...

  7. HTML DOM节点

    在 DOM 树中,基本上一切都是节点.每个元素在最底层上都是 DOM 树中的节点.每个属性都是节点.每段文本都是节点.甚至注释.特殊字符(如版权符号 ©).DOCTYPE 声明(如果 HTML 或者 ...

  8. ie浏览器下input和select的上下居中问题!!!!

    在Google浏览器下的input和select标签里面的文字是根据它的高度自适应上下居中的,而ie浏览器下的input和select里面的文字就不会根据高度自适应上下居中,跟大家分享一下我的解决方法 ...

  9. CSS3 @font-face详细用法(转)

      @font-face是CSS3中的一个模块,他主要是把自己定义的Web字体嵌入到你的网页中,随着@font-face模块的出现,我们在Web的开发中使用字体就不用再为只能使用Web安全字体烦恼了! ...

  10. Linux和windows下清除svn保存的账号密码信息

    linux是什么用户登录就是什么用户的home下,如root用户就是/root,如果xiangdong就是/home/xiangdong 用Svn时会有一种需求是需要换个帐号测试一下什么的,但往往有缓 ...