InnoDB的三个关键特性

http://www.cnblogs.com/benshan/archive/2013/01/14/2859336.html

InnoDB的三个关键特性

InnoDB存储引擎的三个关键特性:插入缓冲(insert buffer)、二次写(double write)、自适应哈希索引(adaptive hash index)。

1、插入缓冲(insert buffer)的原理:

  对于非聚集索引的插入和更新,不是每一次直接插入索引页中,而是首先判断插入的非聚集索引页是否在缓冲池中,如果在,则直接插入,否则,先放入一个插入缓冲区中。好似欺骗数据库这个非聚集的索引已经插入到叶子节点了,然后再以一定的频率执行插入缓冲和非聚集索引页子节点的合并操作,这时通常能将多个插入合并到一个操作中,这就大大提高了对非聚集索引执行插入和修改操作的性能。

  插入缓冲使用的条件:

  1、索引是辅助索引;

  2、索引不是唯一的;

2、两次写(double write)
  两次写给innodb带来的是可靠性,主要用来解决部分写失败(partial page write)。doublewrite有两部分组成,一部分是内存中的doublewrite buffer,大小为2M,另外一部分就是物理磁盘上的共享表空间中连续的128个页,即两个区,大小同样为2M。当缓冲池的胀业刷新时,并不直接写硬 盘,而是通过memcpy函数将脏页先拷贝到内存中的doublewrite buffer,之后通过doublewrite buffer再分两次写,每次写入1M到共享表空间的物理磁盘上,然后马上调用fsync函数,同步磁盘。如下图所示

以下命令可以查看doublewrite的使用 情况。

mysql> show global status like ‘innodb_dblwr%‘;

slave上可以通过设置skip_innodb_doublewrite参数关闭两次写功能来提高性能,但是master上一定要开启此功能,保证数据 安全。

3、自适应哈希索引(adaptive hash index)
  由于innodb不支持hash索引,但是在某些情况下hash索引的效率很高,于是出现了 adaptive hash index功能,innodb存储引擎会监控对表上索引的查找,如果观察到建立hash索引可以提高性能的时候,则自动建立hash索引。可以通过 show engine innodb status\G来查看自适应哈西索引的使用情况。可以使用innodb_adaptive_hash_index来禁用和启用hash索引,默认开启。

时间: 2024-11-10 22:14:24

InnoDB的三个关键特性的相关文章

InnoDB关键特性之double write

# 脏页刷盘的风险 两次写的原理机制 1.解决问题 2.使用场景 3.doublewrite的工作流程 4.崩溃恢复 # doublewrite的副作用 1.监控doublewrite负载 2.关闭doublewrite场景 一.脏页刷盘风险 关于IO的最小单位: 1.数据库IO的最小单位是16K(MySQL默认,oracle是8K) 2.文件系统IO的最小单位是4K(也有1K的) 3.磁盘IO的最小单位是512K 因此,存在IO写入导致page损坏的风险: 二.doublewrite:两次写

INNODB 关键特性

InnoDB关键特性包括: 插入缓冲(Insert BUffer),两次写(Double Write),自适应哈希索引(Adaptive Hash Index), 异步IO(Async IO),刷新邻接页(Flush Neighbor Page) INSERT BUFFER 可能是INNODB 存储引擎关键特性中最令人激动与兴奋的一个功能.INSERT BUFFER和数据页一样,也是物理页的一个组成部分. 插入缓冲被开创性地用于解决这个问题:对于非聚集索引的插入或更新,并不是每次直接插入索引页,

SQL Server 2016 CTP2.3 的关键特性

SQL Server 2016 CTP2.3 的关键特性 数据库方面的增强 Row Level Security已经支持In-memory OLTP 表.用户现在可以对内存优化表实施row-level security策略. 另外SCHEMABINDING.predicate 函数和内联表值函数都要包含NATIVE_COMPILATION编译选项. 使用NATIVE_COMPILATION编译选项的UDFs用户定义函数可以在本地模块和交换查询中使用,就像内存优化表和磁盘表. 没有使用NATIVE

Android动态加载技术三个关键问题详解

编者按:InfoQ开设新栏目“品味书香”,精选技术书籍的精彩章节,以及分享看完书留下的思考和收获,欢迎大家关注.本文节选自任玉刚著<Android开发艺术探索>中的章节“Android的动态加载技术”,探讨了Android动态加载的三个关键问题. 动态加载技术(也叫插件化技术)在技术驱动型的公司中扮演着相当重要的角色,当项目越来越庞大的时候,需要通过插件化来减轻应用的内存和CPU占用,还可以实现热插拔,即在不发布新版本的情况下更新某些模块.动态加载是一项很复杂的技术,这里主要介绍动态加载技术中

RocketMQ 关键特性

Apache RocketMQ之所以能在众多的消息中间件中脱颖而出,能吸引数千企业用户与RocketMQ的关键特性是分不开的,本文详细介绍RocketMQ中的关键特性. 一.过万的单机队列数 诸如Kafka之类的消息中间件,在队列数上升时性能会产生巨大的损失,RocketMQ之所以能单机支持上万的持久化队列与其独特的存储结构分不开. 如上图所示,所有的消息数据单独存储到一个Commit Log,完全顺序写,随机读.对最终用户展现的队列实际只存储消息在Commit Log的位置信息,并且串行方式刷

影响K8S Pod分配和调度策略的两大关键特性

在Kubernetes中有一个最复杂的调度器可以处理pod的分配策略.基于在pod规范中所提及的资源需求,Kubernetes调度器会自动选择最合适的节点来运行pod. 但在许多实际场景下,我们必须干预调度过程才能在pod和一个节点或两个特定pod之间进行匹配.因此,Kubernetes中有一种十分强大的机制来管理及控制pod的分配逻辑. 那么,本文将探索影响Kubernetes中默认调度决定的关键特性. 节点亲和性/反亲和性 Kubernetes一向以来都是依赖label和selector来对

study Mvc step by step (三)C#语言特性扩展方法

C#3.0之后推出了扩展方法.我们通常看到的方法都是和声明它的类相关联.扩展方法特性扩展这个边界,允许编写的方法和声明它的类之外的类关联. 要想知道可以如何使用这个特性,请看下面的代码.它包含类MyPerson.该类存贮了3个double类型的值,并含有一个构造函数和一个名称为sum的方法,该方法返回3个存储值得和. using System; using System.Collections.Generic; using System.Linq; using System.Text; usin

苹果通知推送服务(APNS)关键特性摘要

1. If APNs attempts to deliver a notification but the device is offline, the notification is stored for a limited period of time, and delivered to the device when it becomes available. 假如用户手机不在线,可能没有信号或者关机吧,APNs会存储转发,等用户在线时再发送 2.Only one recent notif

喷漆房的三个关键与原理

抽风式喷漆房的三个关键:1.通风-抽风式喷漆房工作的关键问题.2.过滤-过滤空气中小颗粒灰尘.3.排气-排出废空气吸收新空气.喷漆房的原理:室外空气-喷漆房门过滤布-喷漆台-利用喷漆设备对喷溅喷漆-排风扇(排出产生的漆雾)这种喷漆房的弱点如下:1.过滤布容易划伤,灰尘容易进入.2.易将室外有杂质的空气进入.3.不环保,容易浪费油漆.4.需要经常清理,定期清除过滤布上的污垢.5.抽风的风机易损坏,维修麻烦.