zoukankan      html  css  js  c++  java
  • INNODB引擎概述

    INNODB存储引擎的历史概述:

    INNODB存储引擎是OLTP应用中核心表的首选存储引擎。

    INNODB存储引擎包含在所有mysql数据库的二进制发行版本中。早期其版本随着mysql数据库的更新而更新。

    从mysql5.1开始,mysql数据库允许存储引擎开发商以动态形式加载引擎,这样存储引擎的更新可以不受mysql数据库版本的限制。

    mysql5.1中,可以支持两个版本的INNODB,一个是静态编译的INNODB版本,可以将其看作老版本的INNODB,另外一个是动态加载的INNODB版本,官方称为INNODB plugin,或者INNODB1.0.

    mysqk5.5又将INNODB版本升级到了1.1x

    mysql5.6又将其升级到了1.2x

    各版本之间的比较

    老版本的INNODB:    支持ACID,行锁设计, MVCC
    INNODB1.0x        继承了上述版本的所有功能,增加了compress和dynamic页格式
    INNODB1.1x        继承了上述版本的所有功能,增加了linux AIO,多回滚段
    INNODB 1.2x       继承了上述版本的所有功能,增加了全文索引支持,在线索引添加

    INNODB的后台线程:

    INNODB的后台线程主要作用:刷新内存池中的数据,保证缓冲池中的内存缓存的是最近的数据。 其二:将已修改的数据文件刷新到磁盘文件,同时保证数据库发生异常的情况下INNODB能恢复到正常状态。

    INNODB存储引擎是多线程模型,后台有许多不同的后台线程。

    1:Master Thread

    是一个非常核心的后台线程,主要负责将缓冲池中的数据异步刷新到磁盘,保证数据的一致性。

    2:Io Thread

    在INNODB存储引擎中大量使用了AIO(异步IO)来处理IO请求,这样可以大大提高数据库的性能。

    有四种IO Thread分别为: read, write, insert buffer和log IO thread。

    默认情况下read thred和write thread分别为4个:

    MariaDB [(none)]> show engine innodb statusG
    
    --------
    I/O thread 0 state: waiting for completed aio requests (insert buffer thread)
    I/O thread 1 state: waiting for completed aio requests (log thread)
    I/O thread 2 state: waiting for completed aio requests (read thread)
    I/O thread 3 state: waiting for completed aio requests (read thread)
    I/O thread 4 state: waiting for completed aio requests (read thread)
    I/O thread 5 state: waiting for completed aio requests (read thread)
    I/O thread 6 state: waiting for completed aio requests (write thread)
    I/O thread 7 state: waiting for completed aio requests (write thread)
    I/O thread 8 state: waiting for completed aio requests (write thread)
    I/O thread 9 state: waiting for completed aio requests (write thread)

    如上读线程的id总是小于写线程的id。

    读写线程的个数可以通过如下两个参数控制:

    MariaDB [(none)]> show variables like "innodb_%io_threads"G
    *************************** 1. row ***************************
    Variable_name: innodb_read_io_threads
            Value: 4
    *************************** 2. row ***************************
    Variable_name: innodb_write_io_threads
            Value: 4
    2 rows in set (0.01 sec)
    
    MariaDB [(none)]>

    3: Purge Thread

    事务被提交之后,其所使用的的undo log可能不再需要,因此需要使用Purge thread来回收已经使用并分配的undo页。在innodb1.1之前,purge仅在master thread中完成。innodb1.1之后可以用一个单独的线程来完成。

    innodb_purge_threads=1         #可以在配置文件中指定

    #在innodb1.2之后其参数的值可以设置为大于1,可以启动多个purge thread线程

    4:Page Cleaner Thread

    在innodb1.2版本之后引入的,作用是将之前版本中脏页刷新操作放入单独的线程,减轻master thread的负担。

    参考书籍【MySQL 技术内幕 --innodb存储引擎】

  • 相关阅读:
    实现翻页效果
    使用AHKActionSheet
    [翻译] GSProgressView
    [翻译] NSRegexTester
    下载时获取文件大小
    高级mask应用
    使用UILabel实现滚动字幕移动效果
    动画绘制水波纹
    能产生粒子效果的CAEmitterLayer
    使用UITableView实现图片视差效果
  • 原文地址:https://www.cnblogs.com/wxzhe/p/8876573.html
Copyright © 2011-2022 走看看