Mysql各种存储引擎的特性以及如何选择存储引擎

    作者:课课家教育更新于: 2017-05-18 09:44:08

      MySQL中的数据用各种不同的技术存储在文件(或内存)中,这些技术中的每一种技术都使用不同的存储机制,索引技巧,锁定水平并且最终提供广泛的不同功能和能力。在MySQL中将这些不同的技术及配套的相关功能称为存储引擎。

      MySQL的存储引擎可能是所有关系型数据库产品中最具有特色的了,不仅可以同时使用多种存储引擎,而且每种存储引擎和MySQL之间使用插件方式这种非常松的耦合关系。

      由于各存储引擎功能特性差异较大,这篇文章主要是介绍如何来选择合适的存储引擎来应对不同的业务场景。

      MyISAM

      特性

      不支持事务:MyISAM存储引擎不支持事务,所以对事务有要求的业务场景不能使用

      表级锁定:其锁定机制是表级索引,这虽然可以让锁定的实现成本很小但是也同时大大降低了其并发性能

      读写互相阻塞:不仅会在写入的时候阻塞读取,MyISAM还会在读取的时候阻塞写入,但读本身并不会阻塞另外的读

      只会缓存索引:MyISAM可以通过key_buffer缓存以大大提高访问性能减少磁盘IO,但是这个缓存区只会缓存索引,而不会缓存数据

      适用场景

      不需要事务支持(不支持)

      并发相对较低(锁定机制问题)

      数据修改相对较少(阻塞问题)

      以读为主

      数据一致性要求不是非常高

      最佳实践

      尽量索引(缓存机制)

      调整读写优先级,根据实际需求确保重要操作更优先

      启用延迟插入改善大批量写入性能

      尽量顺序操作让insert数据都写入到尾部,减少阻塞

      分解大的操作,降低单个操作的阻塞时间

      降低并发数,某些高并发场景通过应用来进行排队机制

      对于相对静态的数据,充分利用QueryCache可以极大的提高访问效率

      MyISAM的Count只有在全表扫描的时候特别高效,带有其他条件的count都需要进行实际的数据访问

      InnoDB

      特性

      具有较好的事务支持:支持4个事务隔离级别,支持多版本读

      行级锁定:通过索引实现,全表扫描仍然会是表锁,注意间隙锁的影响

      读写阻塞与事务隔离级别相关

      具有非常高效的缓存特性:能缓存索引,也能缓存数据

      整个表和主键以Cluster方式存储,组成一颗平衡树

      所有SecondaryIndex都会保存主键信息

      适用场景

      需要事务支持(具有较好的事务特性)

      行级锁定对高并发有很好的适应能力,但需要确保查询是通过索引完成

      数据更新较为频繁的场景

      数据一致性要求较高

      硬件设备内存较大,可以利用InnoDB较好的缓存能力来提高内存利用率,尽可能减少磁盘IO

      最佳实践

      主键尽可能小,避免给Secondaryindex带来过大的空间负担

      避免全表扫描,因为会使用表锁

      尽可能缓存所有的索引和数据,提高响应速度

      在大批量小插入的时候,尽量自己控制事务而不要使用autocommit自动提交

      合理设置innodb_flush_log_at_trx_commit参数值,不要过度追求安全

      避免主键更新,因为这会带来大量的数据移动

      MEMORY

      使用MySQLMemory存储引擎的出发点是速度。为得到最快的响应时间,采用的逻辑存储介质是系统内存。虽然在内存中存储表数据确实会提供很高的性能,但当mysqld守护进程崩溃时,所有的Memory数据都会丢失。获得速度的同时也带来了一些缺陷。它要求存储在Memory数据表里的数据使用的是长度不变的格式,这意味着不能使用BLOB和TEXT这样的长度可变的数据类型,VARCHAR是一种长度可变的类型,但因为它在MySQL内部当做长度固定不变的CHAR类型,所以可以使用。

      一般在以下几种情况下使用Memory存储引擎:

      1.目标数据较小,而且被非常频繁地访问。在内存中存放数据,所以会造成内存的使用,可以通过参数max_heap_table_size控制Memory表的大小,设置此参数,就可以限制Memory表的最大大小。

      2.如果数据是临时的,而且要求必须立即可用,那么就可以存放在内存表中。

      3.存储在Memory表中的数据如果突然丢失,不会对应用服务产生实质的负面影响。

      ARCHIVE

      Archive是归档的意思,在归档之后很多的高级功能就不再支持了,仅仅支持最基本的插入和查询两种功能。在MySQL5.5版以前,Archive是不支持索引,但是在MySQL5.5以后的版本中就开始支持索引了。Archive拥有很好的压缩机制,它使用zlib压缩库,在记录被请求时会实时压缩,所以它经常被用来当做仓库使用。

      几个常用存储引擎的特点

    Mysql各种存储引擎的特性以及如何选择存储引擎_数据库_Mysql_存储引擎_课课家教育

      最常使用的2种存储引擎:

      Myisam是Mysql的默认存储引擎。当create创建新表时,未指定新表的存储引擎时,默认使用Myisam。每个MyISAM在磁盘上存储成三个文件。文件名都和表名相同,扩展名分别是.frm(存储表定义)、.MYD(MYData,存储数据)、.MYI(MYIndex,存储索引)。数据文件和索引文件可以放置在不同的目录,平均分布io,获得更快的速度。

      InnoDB存储引擎提供了具有提交、回滚和崩溃恢复能力的事务安全。但是对比Myisam的存储引擎,InnoDB写的处理效率差一些并且会占用更多的磁盘空间以保留数据和索引。

      如何选择合适的存储引擎

      选择标准:根据应用特点选择合适的存储引擎,对于复杂的应用系统可以根据实际情况选择多种存储引擎进行组合。

      下面是常用存储引擎的适用环境:

      MyISAM:默认的MySQL插件式存储引擎,它是在web、数据仓储和其他应用环境下最常使用的存储引擎之一

      InnoDB:用于事务处理应用程序,具有众多特性,包括ACID事务支持。

      Memory:将所有数据保存在RAM中,在需要快速查找引用和其他类似数据的环境下,可提供极快的访问。

      Merge:允许MySQLDBA或开发人员将一系列等同的MyISAM表以逻辑方式组合在一起,并作为1个对象引用它们。对于诸如数据仓储等VLDB环境十分适合。

      小编结语:

      这篇文章总结了几种比较常用的存储引擎,对于实际的工作,需要根据具体的情况而定,结合实际的项目实例进行应用,才是最好的学习方法。

      更多内容尽在课课家教育!

课课家教育

未登录