1. 查看命令
#看你的mysql如今已提供什么存储引擎:
mysql> show engines;mysql
#看你的mysql当前默认的存储引擎:
mysql> show variables like '%storage_engine%';redis
2.各个引擎简介
一、InnoDB存储引擎
InnoDB是MySQL的默认事务型引擎,它被设计用来处理大量的短时间(short-lived)事务。除非有很是特别的缘由须要使用其余的存储引擎,不然应该优先考虑InnoDB引擎。行级锁,适合高并发状况
二、MyISAM存储引擎
MyISAM提供了大量的特性,包括全文索引、压缩、空间函数(GIS)等,但MyISAM不支持事务和行级锁(myisam改表时会将整个表全锁住),有一个毫无疑问的缺陷就是崩溃后没法安全恢复。
三、Archive引擎
Archive存储引擎只支持INSERT和SELECT操做,在MySQL5.1以前不支持索引。
Archive表适合日志和数据采集类应用。适合低访问量大数据等状况。
根据英文的测试结论来看,Archive表比MyISAM表要小大约75%,比支持事务处理的InnoDB表小大约83%。
四、Blackhole引擎
Blackhole引擎没有实现任何存储机制,它会丢弃全部插入的数据,不作任何保存。但服务器会记录Blackhole表的日志,因此能够用于复制数据到备库,或者简单地记录到日志。但这种应用方式会碰到不少问题,所以并不推荐。
五、CSV引擎
CSV引擎能够将普通的CSV文件做为MySQL的表来处理,但不支持索引。
CSV引擎能够做为一种数据交换的机制,很是有用。
CSV存储的数据直接能够在操做系统里,用文本编辑器,或者excel读取。
六、Memory引擎
若是须要快速地访问数据,而且这些数据不会被修改,重启之后丢失也没有关系,那么使用Memory表是很是有用。Memory表至少比MyISAM表要快一个数量级。(使用专业的内存数据库更快,如redis)
七、Federated引擎
Federated引擎是访问其余MySQL服务器的一个代理,尽管该引擎看起来提供了一种很好的跨服务器的灵活性,但也常常带来问题,所以默认是禁用的。
sql
3.MyISAM和InnoDB对比
innodb 索引 使用 B+TREE myisam 索引使用 b-tree
innodb 主键为聚簇索引,基于聚簇索引的增删改查效率很是高。数据库
4.扩展
Percona 为 MySQL 数据库服务器进行了改进,在功能和性能上较 MySQL 有着很显著的提高。该版本提高了在高负载状况下的 InnoDB 的性能、为 DBA 提供一些很是有用的性能诊断工具;另外有更多的参数和命令来控制服务器行为。
该公司新建了一款存储引擎叫xtradb彻底能够替代innodb,而且在性能和并发上作得更好,
阿里巴巴大部分mysql数据库其实使用的percona的原型加以修改。
AliSql+AliRedis安全