• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    mysql innodb的重要组件汇总

    innodb包涵如下几个组件 

    一、innodb_buffer_pool:

           它主要用来缓存数据与索引(准确的讲由于innodb中的表是由聚集索引组织的,所以数据只不是过主键这个索引的叶子结点)。 

    二、change buffer:

      1  如果更新语句要更新二级索引的记录,但是记录所在的页面这个里面并没有在innodb_buffer_pool中,innodb会把这个对二级索引

      面页的更新动作缓存到innodb_buffer_pool的一个特定区域(change buffer);等到之后如果有别的事务B要去读这个二级索引页的时候,

      由于页面还没有,在innodb_buffer_pool中所以B事务会先把页面载入innodb_buffer_pool,这样子目标页面就算进入innodb_buffer_pool了,

      接下来就可根据change buffer的内容来更新索引页面了。这样可以节约IO操作,提高性能。

      2  当然别的刷新机(把change buffer中的变更落盘)制也是有的,比如说当mysql比较空闲的时候,slow shutdown 的过程当中也会刷新

      change buffer中的内容到磁盘

      3  监控change buffer 

    show engine innodb status;
    
    -------------------------------------
    INSERT BUFFER AND ADAPTIVE HASH INDEX
    -------------------------------------
    Ibuf: size 1, free list len 0, seg size 2, 0 merges
    merged operations:
     insert 0, delete mark 0, delete 0
    discarded operations:
     insert 0, delete mark 0, delete 0
    Hash table size 34679, node heap has 0 buffer(s)
    Hash table size 34679, node heap has 0 buffer(s)
    Hash table size 34679, node heap has 0 buffer(s)
    Hash table size 34679, node heap has 0 buffer(s)
    Hash table size 34679, node heap has 0 buffer(s)
    Hash table size 34679, node heap has 0 buffer(s)
    Hash table size 34679, node heap has 0 buffer(s)
    Hash table size 34679, node heap has 0 buffer(s)
    0.00 hash searches/s, 0.00 non-hash searches/s
    ---
    LOG
    ---
    Log sequence number 24635311
    Log flushed up to 24635311
    Pages flushed up to 24635311
    Last checkpoint at 24635302
    0 pending log flushes, 0 pending chkp writes
    10 log i/o's done, 0.00 log i/o's/second

    三、自适应hash索引:

      1  如果表中的某些行会非常频繁的用到,由于innodb表是B+树组织起来的这一特性,最好的情况下innodb也是先读索引页,再读数据页,然后

      找到数据;hash索引是用B+树索引的hash为键,以B+树索引的值(指向的页面)为值的;由于有了hash索引的引入,innodb可以通过计算索引的hash

      值就直接定位到数据所在的页面;所以对于非范围查找的情况下hash索引这样的处理方式是有优势的。

      2  要想innodb能用上bash索引还要有几个条件1、innodb_adaptive_hash_index=1 这样innodb就会启用hash索引了;然而这只是完成了一半,

      innodb并不是为表中的所有行建立hash索引的,只是表中频繁访问的行才会为它建立hash索引,为冷数据建立hash索引是一种浪费;

      innodb_adaptive_hash_index_parts 可以设置hash索引的分区,这种可以提升并发度。

    四、redo log buffer:

      redo log buffer 中的内容会被定期的刷新到磁盘,如果redo log buffer 设置的比较大它有利于mysql对大事务的处理,原因在于在大事务的处理中

      可以把redo 写入到redo log buffer 而不是写入到磁盘,由于内存比磁盘快,所以大事务的处理速度上也会比较快;也就是说redo log buffer 比较大

      的情况下在commit 之前可以减少一些没有必要的刷磁盘操作。

    五、系统表空间:

      innodb 系统表空间中包涵如下内容:innodb 数据字典,一些存储区域如 doublewrite\changebuffer\undolog ,如果innodb_file_per_table

      没有打开那么那么用户建的表就会保存到这个系统表空间中,这种情况下系统表空间也就可以看面它包涵共享表空间了。

    以上就是mysql innodb的重要组件汇总的详细内容,更多关于mysql innodb组件的资料请关注脚本之家其它相关文章!

    您可能感兴趣的文章:
    • 详解MySQL InnoDB存储引擎的内存管理
    • MySQL Innodb关键特性之插入缓冲(insert buffer)
    • MySQL InnoDB 锁的相关总结
    • 如何区分MySQL的innodb_flush_log_at_trx_commit和sync_binlog
    • Mysql InnoDB的锁定机制实例详解
    • Mysql技术内幕之InnoDB锁的深入讲解
    • 修改MySQL数据库引擎为InnoDB的操作
    • Mysql InnoDB和MyISAM区别原理解析
    • 获取 MySQL innodb B+tree 的高度的方法
    • MySQL InnoDB ReplicaSet(副本集)简单介绍
    上一篇:详解mysql持久化统计信息
    下一篇:解决MySQL读写分离导致insert后select不到数据的问题
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    mysql innodb的重要组件汇总 mysql,innodb,的,重要,组件,