INNODB,是Mysql5.7的默认存储引擎,是事务安全的,支持ACID,具有提交,回滚和crash-recovery【灾备】能力,以保护用户数据。

优势:一旦Server崩溃,Innodb会自动保存已提交的数据,undo未被提交的事务;不会产生业务上的影响。

Innodb buffer pool 会缓存被访问的数据,可加速数据处理。

将关联数据拆分到多个表,需建立外键【foreign key】以确保数据完整性。

为表建立适当的主键【primary key】,这样在引用主键时where ,order by ,group by ,join 会很快。

在 insert,update ,delete 时自动使用change buffering机制,缓存已更改数据。

Adaptive Hash Index 风格会加快耗时的重复数据查询。

压缩表和相关index.

可以较小的影响【性能和可用性】来创建和删除index.

使用DYNAMIC row format,对于BLOB和长文本类型的处理更高效。

可以通过查询 INFORMATION_SCHEMA中表来监控存储引擎的内部工作情况。

通过查询performance_schema中表来监控存储引擎的详细性能信息。

For InnoDB-specific tuning techniques you can apply in your application code, see Section 9.5, “Optimizing for InnoDB Tables”.

Innodb 现可以使用FULLTEXT索引执行全文检索;

Innodb 现在具有更出色的读表现。

布置于只读媒介上的程序现可以使用Innodb表。

InnoDB 是多版本控制存储引擎,将被改变行的旧版本信息存储于表空间的rollback segment 区域中。Innodb可使用该区域的信息执行undo操作【在事务回滚时】;也使用该信息构建譔行的早期版本数据。

 INNODB configure

INNODB buffer pool is used to cache data and index in memory.In configue file ,innodb_buffer_pool_size is about 50%-80% of computer's memory.

innodb_old_blocks_pct, 在buffer pool 中旧数据的占比【百分比】

innodb_old_blocks_time,在buffer Pool 中被插入旧区中的数据在第一次被访问多久后再移入新区【如果还存在】

innodb_buffer_pool_chunk_size

在设置innodb_buffer_pool_instances时,保证每一个buffer_pool实例都至少有一个GB,这样才能够最大可能的提高效率,默认时innodb_buffer_pool_instances=1。

在innodb_buffer_pool的管理上,Mysql不是使用严格意义上的LRU算法,Innodb使用了一种技术来最大化的减少被载入Buffer Pool但从没使用的数据。innodb_old_blocks_pct,设置非热点数据占比,默认37%,该值不应过高;innodb_old_blocks_time,设值窗口时间,即在这个时间内的访问不被载入新区,该值设置越大,数据过期的越快,默认一秒【1000】。

监测Buffer pool 的设置效果,可使用 SHOW ENGINE INNODB STATUS,查看buffer pool 使用统计情况。

如:

配置Innodb中dirty pages处理,在Innodb中有专门的后台Task做Flushing的操作,有两个触发临界点:一个是innodb_max_dirty_pages_pct,设置dirty pages的占比,当大于等于该占比时触发Flushing【根据RedoLog的产生速度和刷新频率来确定实际占比】;第二个是当Log文件的空间用尽,达到sharp checkpoiont而进行Flushing【这种大量IO会对Mysql性能产生较大影响】,为了避免这种情形出现,可使用自适应算法【self-adapting algorithm】,可通过innodb_adaptive_flushing来设置期启用与否。

我们知道buffer pool里存放了很多热点数据,为了在重启Server时恢复最最常用的热点数据,加速预热,我们可以保存Buffer pool 的状态信息以便恢复时使用。

可通过innodb_buffer_pool_dump_at_shutdown,innodb_buffer_pool_load_at_startup来配置是否启用buffer pool 状态保存,innodb_buffer_pool_dump_pct配置舍弃热点数据的百分比【25-100】。其实保存文件是很小的,因为其中只保存了定位数据的位置信息【tablespaceId和pageId】,保存文件默认是在Data directory下的ib_buffer_pool。保存的这些位置信息其实来自于information_schema.innodb_buffer_page_lru表中。当然该文件路径名称也可以通过系统变量:innodb_buffer_pool_filename配置。

如果需要紧急保存状态,可 set Global innodb_buffer_pool_dump_now=ON;若在运行时想恢复,可set global innodb_buffer_pool_load_now=ON;

Mysql 有单独的后台线程来做这个事。

显示Buffer pool dump和load进程状态信息:

INNODB的更多相关文章

  1. MySQL数据库和InnoDB存储引擎文件

    参数文件 当MySQL示例启动时,数据库会先去读一个配置参数文件,用来寻找数据库的各种文件所在位置以及指定某些初始化参数,这些参数通常定义了某种内存结构有多大等.在默认情况下,MySQL实例会按照一定 ...

  2. InnoDB关键特性学习笔记

    插入缓存 Insert Buffer Insert Buffer是InnoDB存储引擎关键特性中最令人激动与兴奋的一个功能.不过这个名字可能会让人认为插入缓冲是缓冲池中的一个组成部分.其实不然,Inn ...

  3. InnoDB体系结构学习笔记

    后台线程 Master Thread 核心的后台线程,主要负责将缓冲池的数据异步刷新到磁盘,保证数据的一致性,包括(脏页的刷新).合并插入缓冲.(UNDO页的回收)等 IO Thread 4个writ ...

  4. InnoDB:Lock & Transaction

    InnoDB 是一个支持事务的Engine,要保证事务ACID,必然会用到Lock.就像在Java编程一下,要保证数据的线程安全性,必然会用到Lock.了解Lock,Transaction可以帮助sq ...

  5. innodb 自增列重复值问题

    1 innodb 自增列出现重复值的问题 先从问题入手,重现下这个bug use test; drop table t1; create table t1(id int auto_increment, ...

  6. MySql - InnoDB - 事务 , Php版

    (出处:http://www.cnblogs.com/linguanh/) 1,前序 由于要重构APP(社交类) 服务端接口的部分代码,故接触到了 innoDB,以及事务这个词,下面主要是以例子的形式 ...

  7. MySQL的InnoDB索引原理详解

    摘要 本篇介绍下Mysql的InnoDB索引相关知识,从各种树到索引原理到存储的细节. InnoDB是Mysql的默认存储引擎(Mysql5.5.5之前是MyISAM,文档).本着高效学习的目的,本篇 ...

  8. MySQL存储引擎--MyISAM与InnoDB区别

    InnoDB和MyISAM是许多人在使用MySQL时最常用的两个表类型,这两个表类型各有优劣,视具体应用而定.基本的差别为:MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持.MyISA ...

  9. MySQL 从 5.5 升级到 5.6,启动时报错 [ERROR] Plugin 'InnoDB' init function returned error

    MySQL 从 5.5 升级到 5.6,启动时报错: [ERROR] Plugin 'InnoDB' init function returned error. [ERROR] Plugin 'Inn ...

  10. Mysql 存储引擎中InnoDB与Myisam的主要区别

    一直以为我spring事物没有配置好,结果发现是mysql的表本身设置成了Myisam 引擎.改成innodb就支持事物了. 1, 事务处理 innodb 支持事务功能,myisam 不支持. Myi ...

随机推荐

  1. java中堆栈(stack)和堆(heap)(还在问静态变量放哪里,局部变量放哪里,静态区在哪里.....进来)

    (1)内存分配的策略 按照编译原理的观点,程序运行时的内存分配有三种策略,分别是静态的,栈式的,和堆式的. 静态存储分配是指在编译时就能确定每个数据目标在运行时刻的存储空间需求,因而在编 译时就可以给 ...

  2. C#操作word模板插入文字、图片及表格详细步骤

    c#操作word模板插入文字.图片及表格 1.建立word模板文件 person.dot用书签 标示相关字段的填充位置 2.建立web应用程序 加入Microsoft.Office.Interop.W ...

  3. iOS开发——高级篇——UIDynamic 物理引擎

    一.UIDynamic 1.简介什么是UIDynamicUIDynamic是从iOS 7开始引入的一种新技术,隶属于UIKit框架可以认为是一种物理引擎,能模拟和仿真现实生活中的物理现象重力.弹性碰撞 ...

  4. 5分钟教你Windows 10中将“运行”固定到开始菜单

    导读 “运行”功能深受很多资深IT之家用户喜爱,因为它简约.方便.实用.在Win7等旧版系统中,用户可以让该功能直接在开始菜单显示,方便操作.但在Win10中,由于开始菜单已经重新编写,原有的设定已经 ...

  5. android快速开发框架

    网络: socket: mina http: http://loopj.com/android-async-http/ UI: http://jakewharton.github.io/butterk ...

  6. 使用JavaScript在项目前台开发的58种常用小技巧

    oncontextmenu="return false" :禁止右键 onselectstart="return false" : 禁止选取 onpaste = ...

  7. PYTHON 购物车程序

    product_list = [ ('iphone',50000), ('Mac Pro',9900), ('Bike',8000), ('Watch',160000), ('Coffee',600) ...

  8. 剑指Offer 从上往下打印二叉树(dfs)

    题目描述 从上往下打印出二叉树的每个节点,同层节点从左至右打印.   思路: 用一个队列来辅助,先压入根节点,设置一个指针记录队列头位置,判断队头指针有没有孩子,有压入左右孩子,,,操作完一次,队头出 ...

  9. CISCO系列交换机如何清空配置

    今天刚好要还原一台CISCO配置的命令,这个毕竟属于我的专业小编就献丑一回,望大家见谅! 工具/原料   CISCO系列交换 方法/步骤   1 首先备份之前的配置信息 copy flash:conf ...

  10. Shape + Selector: Make a Shape as one item of the Selector

    Generally, I use a selector to select pictures or colors to render the normal and the pressed backgr ...