MySIAM与Innodb引擎

  1. 云栖社区>
  2. 博客>
  3. 正文

MySIAM与Innodb引擎

科技探索者 2017-11-11 19:28:00 浏览726
展开阅读全文

 在MySQL5.1之前的版本中,默认是MySIAM引擎,每个MySIAM在磁盘上会将数据存储成三个文件。
第一个是表结构文件,它的名字以表的名字开始,其扩展会指出文件类型,为.frm 文件存储表定义;
第二个文件,其拓展名.MYD;
第三个文件是索引文件,其扩展名是.MYI(MYINDEX)

MyISAM存储引擎的特定是表级锁,不支持事务和全文索引,适合一些CMS内容管理系统作为后台数据库使用,但是在大并发,重负荷生产系统上,表级锁的特性显得力不从心,并且如果系统出现宕机,MySQLd进程崩溃,MyISAM引擎很容易受损害,这时候不得不使用MyISAMchk去修复她,基于这个原因,从MySQL5.5开始,默认的存储引擎变成了InnoDB Plugin引擎

InonoDB给Mysql提供了具有提交,回滚和崩溃恢复能力的事务安全存储引擎。其SELECT语句与Oracle风格一致--非锁定读。准确的说InnoDB是为处理巨大的数据量时拥有最大的性能而设定的。它的CPU效率是其他任何基于磁盘的关系数据库引擎所不能匹敌的。

在诸多高并发,高压力的大型数据库站点上,Innodb用的非常广泛。有些站点的InnoDB上处理平均每秒800此插入/更新的负荷。
 
在5.1版本中,innodb_file _io_threads 参数默认是4,该参数在Linux系统上是不能更改的,但是windows系统上可以调整。这个参数的作用是INnodb使用后台线程处理数据页上读写I/O请求的数量。在5.5版本以后,用两个新的参数取代了innodb_file_io_threads,调整后,在Linux平台上就可以根据CPU核心数来更改相应的参数了,默认是4.

加入CPU有两颗8核心的,那么可以设置为:
innodb_read_io_threads =8
innodb-write_io_threads=8
如果数据库的读操作比写多,那么可以设置:
 
innodb_read_io_threads =10

innodb-write_io_threads=6
至于具体的设置方法,需要根据你们公司的情况来设置。不过需要注意的事,这两个参数不支持动态改变,需要把参数写到My.cn里,修改完后记得重启,允许值为1-64.调整完之后,你可以使用   show engine innodb status \G ; 

本文转自xinsz08の平行时空博客51CTO博客,原文链接http://blog.51cto.com/xinsz08/1915908如需转载请自行联系原作者


维度2018

网友评论

登录后评论
0/500
评论