文档章节

MySQL InnoDB存储引擎

Huangchp
 Huangchp
发布于 2017/09/11 16:29
字数 474
阅读 19
收藏 0

InnoDB支持事务,其设计主要面小在线事务处理(OLTP online transaction processing),读取数据时不会产生锁,是MySQL 5.x 版本后的默认存储引擎,SELECT * FROM information_schema.plugins;查看MySQL版本的详细信息。

MySQL体系架构

通过后台线程将文件中的数据刷新到缓存中,或从缓存中将数据存储到文件中。

后台线程

Master Thread:负责将缓存中的数据异步刷新到磁盘中,保证数据的一致性。

IO Thread:为了提高性能,InnoDB使用了大量的AIO线程。参数为innodb_read_io_threads和innodb_write_io_threads,并且默认会启动4个。

Pugre Thread:事务提交后,该线程会回收已经使用并分配的undo页。undo记录的是事务的逆向操作,用于回滚及MVCC,参数为innodb_purge_threads相应的redo记录的是页的重做日志。

Page Cleaner Thread:该线程是InnoDb 1.2.x版本引入,作用是将之前版本中的脏页刷新操作都放到单独的线程中完成。

缓冲池:缓冲池其实就是一块内存区域,用过innodb_buffer_pool_size设置其大小。缓冲池中包含数据页,索引页,插入缓存,锁信息,自适应哈希索引,数据字典信息,重做日志缓存,额外内存池。缓存池可以有多个,通过哈希值存到不同的缓存区域。通过innodb_buffer_pool_instances设置缓存池数量。

InnoDB特性

1、插入缓存:Insert Buffer,Delete Buffer,Purge Buffer,分别对应INSERT,DELETE,UPDATE操作。

2、两次写:保证数据的可靠性,通过两次写恢复数据更准确。

3、自适应哈希索引:提高查询效率。

4、异步IO:提高磁盘的操作性能。

5、刷新临接页:当数据库刷新数据脏页时,同时也会刷新该页所在区域的所有脏页。

© 著作权归作者所有

共有 人打赏支持
Huangchp
粉丝 2
博文 43
码字总数 9988
作品 0
吉林
mysql myisam innodb 区别

最近连续接到了两次tencent的电话面试,当然不是同一个部门。都涉及到了一个mysql的基础知识问题。为了防止第三次打电话来,备注下。^^。 题目1:讲讲你对mysql myisam,innodb的认识。然后你...

马丁博客
2010/10/08
0
0
MYSQL之一步到位之InnoDB

快速认识InnoDB InnoDB是MySQL下使用最广泛的引擎,它是基于MySQL的高可扩展性和高性能存储引擎,从5.5版本开始,它已经成为了默认引擎。 InnODB引擎支持众多特性: a) 支持ACID,简单地说就...

SANSOM
2013/04/23
0
1
MySQL存储引擎InnoDB与Myisam的六大区别

MySQL有多种存储引擎,每种存储引擎有各自的优缺点,可以择优选择使用: MyISAM、InnoDB、MERGE、MEMORY(HEAP)、BDB(BerkeleyDB)、EXAMPLE、FEDERATED、ARCHIVE、CSV、BLACKHOLE。 MySQL支持...

Junn
2013/12/11
0
2
MySQL性能优化系列-01原理与概念

MySQL概述 MySQL数据库目前已被Oracle收购,并发展处多个版本。目前使用最广泛且免费的MySQL版本是MySQL Community(社区版),另外还有三个付费的MySQL版本MySQL Standard(MySQL标准版)、...

东皇巴顿
2017/04/25
0
0
MySQL查看和修改表的存储引擎

1 查看系统支持的存储引擎 show engines; 2 查看表使用的存储引擎 两种方法: a、show table status from dbname where name='tablename'; b、show create table table_name; 如果显示的格式...

Amamatthew
2014/09/29
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

c语言之内存分配笔记

先看一个数组: short array[5] = {1,2} // 这儿定义的一个int类型的数组,数组第1和第2个元素值是1和2.其余后面默认会给值为0; 或者 short array[] = {1,2};//这儿数组第1和第2个元素,数组...

DannyCoder
今天
2
0
Shell | linux安装包不用选择Y/N的方法

apt-get install -y packageOR echo "y" | sudo apt-get install package

云迹
今天
2
0
Hadoop的大数据生态圈

基于Hadoop的大数据的产品圈 大数据产品的一句话概括 Apache Hadoop: 是Apache开源组织的一个分布式计算开源框架,提供了一个分布式文件系统子项目(HDFS)和支持MapReduce分布式计算的软件架...

zimingforever
今天
5
0
八大包装类型的equals方法

先看其中一个源码 结论:八大包装类型的equals方法都是先判断类型是否相同,不相同则是false,相同则判断值是否相等 注意:包装类型不能直接用==来等值比较,否则编译报错,但是数值的基本类型...

xuklc
今天
2
0
NoSQL , Memcached介绍

什么是NoSQL 非关系型数据库就是NoSQL,关系型数据库代表MySQL 对于关系型数据库来说,是需要把数据存储到库、表、行、字段里,查询的时候根据条件一行一行地去匹配,当量非常大的时候就很耗...

TaoXu
昨天
5
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部