加入收藏 | 设为首页 | 会员中心 | 我要投稿 济南站长网 (https://www.0531zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MySQL的浅谈InnoDB存储引擎

发布时间:2016-08-14 06:57:18 所属栏目:MySql教程 来源:站长网
导读:InnoDB是事务安全的存储引擎,设计上借鉴了很多Oracle的架构思想,一般而言,在OLTP应用中,InnoDB 应该作为核心应用表的首先存储引擎。InnoDB是由第三方的Inno
InnoDB是事务安全的存储引擎,设计上借鉴了很多Oracle的架构思想,一般而言,在OLTP应用中,InnoDB 应该作为核心应用表的首先存储引擎。InnoDB是由第三方的Innobase Oy公司开发,现已被Oracle收购,创始 人是Heikki Tuuri,芬兰赫尔辛基人,和著名的Linux创始人Linus是校友。

InnoDB体系架构

MySQL的浅谈InnoDB存储引擎

上面是InnoDB的一个简图,简单来说,InnoDB是由一系列后台线程和一大块内存组成。

后台线程

默认情况下,InnoDB的后台线程有7个 —— 4个IO thread, 1个master thread, 1个lock monitor thread, 一个error monitor thread

内存

InnoDB的内存主要有以下几个部分组成:缓冲池 (buffer pool)、重做日志缓冲池(redo log buffer)以及额外的内存池(additional memory pool),如下 图所示:

MySQL的浅谈InnoDB存储引擎

其中缓冲池占最大块内存,用来缓存各自数据,数据文件按页(每页16K)读取到缓冲池,按最近最少使 用算法(LRU)保留缓存数据。

缓冲池缓冲的数据类型有:数据页、索引页、插入缓冲、自适应哈希 索引、锁信息、数据字典信息等,其中数据页和索引页占了绝大部分内存。

日志缓冲将重做日志信息 先放入这个缓冲区,然后按一定频率(默认为1s)将其刷新至重做日志文件。

(编辑:济南站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读