一.后台进程(innodb 1.0.x以前的)

1.master thread

master thread具有最高的线程优先级别,其内部由多个循环(loop)组成:主循环(loop)、后台循环(backgroup loop)、刷新循环(flush loop)、暂停循环(suspend loop)

①loop:每秒钟的操作和每10s的操作

每秒的操作:

...日志缓冲刷新到磁盘,即使这个事务还没有提交(总是)

...合并插入缓冲(可能):

并不是每秒都发生,innodb存储引擎会判断当前一秒内发生的io次数是否小于5次,如果小于5次,innodb认为当前的io压力很小,可以执行合并插入缓冲操作。

...至少刷新100个innodb的缓冲池中的脏页到磁盘(可能)

innodb存储引擎通过判断当前缓冲池中脏页的比例(buf_get_modified_ratio_pct)是否超过了配置文件中innodb_max_dirty_pages_pct这个参数

...如果当前没有用户活动,则切换到backgroup loop(可能)

每10s的操作

...刷新100个脏页到磁盘(可能的情况下)

...合并至多5个插入缓冲(总是)

...将日志缓冲刷新到磁盘(总是)

...删除无用的undo页(总是)

...刷新100个或者10个脏页到磁盘(总是)

2.background loop

若当前没有用户活动(数据库空闲时)或者数据库关闭(shutdown),就会切换到这个循环

...删除无用的undo页(总是)

...合并20个插入缓冲(总是)

...跳回到主循环(总是)

...不断刷新100个页直到符合条件(可能,跳转到flush loop中完成)

innodb1.2.x以前的

innodb_io_capacity:表示磁盘io的吞吐量,默认值为200

...在合并插入缓冲时,合并插入缓冲的数量为innodb_io_capacity值得5%

...在从缓冲区刷新脏页时,刷新脏页的数量为innodb_io_capacity

若用户使用了ssd类的磁盘,或者将几块磁盘做了raid,当存储设备拥有更高的io速度时,完全可以将innodb_io_capacity的值调的再高点,直到符合磁盘io的吞吐量为止

innodb_max_dirty_pages_pct:改为默认75%

innodb_adaptive_flushing:此功能会当脏页的比例小于innodb_max_dirty_pages_pct时,也会刷新一定量的脏页

innodb_purge_batch_size:之前每次进行full purge操作时,最多回收20个undo页,该参数可以控制每次full purge回收的undo页

show engine innodb status\G;

其中每秒的loop次数与sleep次数比例接近1:1,每10s的loop与sleep次数接近1:10,如是这种情况,则说明数据库较闲,如果loop次数与sleep次数大于1:1,说明数据库比较忙,睡觉的时间少了。

innodb 1.2.x

从master thread线程分离到一个单独的page cleaner thread,从而减轻了master thread的工作

innodb 体系结构(后台进程)的更多相关文章

  1. Mysql Innodb体系结构

    Innodb体系结构 Innodb存储引擎主要包括内存池以及后台线程. 内存池:多个内存块组成一个内存池,主要维护进程/线程的内部数据.缓存磁盘数据,修改文件前先修改内存.redo log 后台线程: ...

  2. 《Mysql技术内幕,Innodb存储引擎》——Innodb体系结构

    Innodb体系结构 Innodb存储引擎主要包括内存池以及后台线程. 内存池:多个内存块组成一个内存池,主要维护进程/线程的内部数据.缓存磁盘数据,修改文件前先修改内存.redo log 后台线程: ...

  3. InnoDB体系结构

    1.前言 整理了下InnoDB体系结构,方便以后更简单的理解 2.思维导图 参考: https://www.cnblogs.com/tangshiguang/p/6741035.html https: ...

  4. [小结]InnoDB体系结构及工作原理

    参阅:<innodb存储引擎内幕>原创文章,会不定时更新,转发请标明出处:http://www.cnblogs.com/janehoo/p/7717041.html 一.概述: innod ...

  5. [原创]InnoDB体系结构

    参阅:<innodb存储引擎内幕> innodb整体的体系结构如下图所示:  整体结构分两大部分:内存和进程其中内存包括:buffer_pool\redo log buffer\addit ...

  6. InnoDB体系结构学习笔记

    后台线程 Master Thread 核心的后台线程,主要负责将缓冲池的数据异步刷新到磁盘,保证数据的一致性,包括(脏页的刷新).合并插入缓冲.(UNDO页的回收)等 IO Thread 4个writ ...

  7. Innodb的体系结构

    MySQL的体系结构,两部分组成:MySQL的server层和存储引擎层. 存储引擎层innodb体系结构: innodb的整个体系结构就是由多个内存块组成的缓冲池及多个后台进程组成.我们可以从三方面 ...

  8. MySQL InnoDB 存储引擎原理浅析

    注:本文主要基于MySQL 5.6以后版本编写,多数知识来着书籍<MySQL技术内幕++InnoDB存储引擎>,本文章仅记录个人认为比较重要的部分,有兴趣的可以花点时间读原书. 一.MyS ...

  9. 第四课(1)——MySQL体系结构

    学习目标 一.MySQL体系结构 二.MySQL内存结构 三.MySQL文件结构 四.Innodb体系结构 MySQL体系结构 一.MySQL体系结构图 1.Mysql是由SQL接口,解析器,优化器, ...

随机推荐

  1. 一本通之 一堆迷宫 (Dungeon Master&走出迷宫&走迷宫)

    一本通在线崩溃....... . 有图有真相 这是个三维迷宫,其实和二位迷宫差不多,只是方向多加了2个. 但这个题的输入十分恶心,一度被坑的用cin.ignore(),但还是不过... 它的正确输入方 ...

  2. python3 模拟鼠标和键盘操作

    1. 安装pyperclip pip install pyperclip 使用方法复制 pyperclip.copy("hello world") 粘贴 pyperclip.pas ...

  3. 线程相关的sleep()、yield()、wait()、join()方法介绍

    1.Thread.sleep()与Thread.yield()都会暂缓当前线程执行,转为执行其他线程(忽略优先级),如果持有锁,则不会释放. 2.Thread.sleep()可以精确指定休眠的时间,而 ...

  4. linux下怎么清理缓存

    free -m 命令可以查看内存使用情况 sysctl 命令可以临时改变某个系统参数  如:sysctl -w net.ipv4.ip_forward=1 是将forware参数临时改为1 当 ser ...

  5. Linux基础之常用命令整理(二)

    Linux系统启动流程 bios(找到启动介质) --> mbr(找到boot loader  512B 446引导信息 64分区信息 2 标志位 ) -->grub(选择操作系统或者内核 ...

  6. Python对wav文件的重采样

    例如从2channel,4.41k hz 重采样到 1 channel,16k hz def downsampleWav(src, dst, inrate=44100, outrate=16000, ...

  7. C语言排序算法学习笔记——交换类排序

    交换类排序:根据序列中两个元素关键字的比较结果来交换他俩在序列中的位置. 冒泡排序:假设待排序表长为n,从后往前(或从前往后)两两比较相邻元素的值,若为逆序(即A[i-1]>A[i])则交换他们 ...

  8. WebApp的自动测试工具: protractor和selenium

    Protractor是Selenium的扩充,支持Angularjs element(by.css('my-css')).click(); 一.用by的各种Locator定位元素 选中1个元素: el ...

  9. postgresql清理工具

    1. 每个DB都单独进行了vacuumdb的命令: vacuumdb -d mydb -z -v 2. full vacuum : vacuumdb -a  -f -z -v  .  自动vacuum ...

  10. sublimetext 创建一个php命令行编译环境

    菜单栏=>工具->编译系统=>新编译系统(插入如下代码,前提是有php批处理 然后编译php ctrl+b即可) { "cmd": ["php" ...