innodb 体系结构(后台进程)
一.后台进程(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 体系结构(后台进程)的更多相关文章
- Mysql Innodb体系结构
Innodb体系结构 Innodb存储引擎主要包括内存池以及后台线程. 内存池:多个内存块组成一个内存池,主要维护进程/线程的内部数据.缓存磁盘数据,修改文件前先修改内存.redo log 后台线程: ...
- 《Mysql技术内幕,Innodb存储引擎》——Innodb体系结构
Innodb体系结构 Innodb存储引擎主要包括内存池以及后台线程. 内存池:多个内存块组成一个内存池,主要维护进程/线程的内部数据.缓存磁盘数据,修改文件前先修改内存.redo log 后台线程: ...
- InnoDB体系结构
1.前言 整理了下InnoDB体系结构,方便以后更简单的理解 2.思维导图 参考: https://www.cnblogs.com/tangshiguang/p/6741035.html https: ...
- [小结]InnoDB体系结构及工作原理
参阅:<innodb存储引擎内幕>原创文章,会不定时更新,转发请标明出处:http://www.cnblogs.com/janehoo/p/7717041.html 一.概述: innod ...
- [原创]InnoDB体系结构
参阅:<innodb存储引擎内幕> innodb整体的体系结构如下图所示: 整体结构分两大部分:内存和进程其中内存包括:buffer_pool\redo log buffer\addit ...
- InnoDB体系结构学习笔记
后台线程 Master Thread 核心的后台线程,主要负责将缓冲池的数据异步刷新到磁盘,保证数据的一致性,包括(脏页的刷新).合并插入缓冲.(UNDO页的回收)等 IO Thread 4个writ ...
- Innodb的体系结构
MySQL的体系结构,两部分组成:MySQL的server层和存储引擎层. 存储引擎层innodb体系结构: innodb的整个体系结构就是由多个内存块组成的缓冲池及多个后台进程组成.我们可以从三方面 ...
- MySQL InnoDB 存储引擎原理浅析
注:本文主要基于MySQL 5.6以后版本编写,多数知识来着书籍<MySQL技术内幕++InnoDB存储引擎>,本文章仅记录个人认为比较重要的部分,有兴趣的可以花点时间读原书. 一.MyS ...
- 第四课(1)——MySQL体系结构
学习目标 一.MySQL体系结构 二.MySQL内存结构 三.MySQL文件结构 四.Innodb体系结构 MySQL体系结构 一.MySQL体系结构图 1.Mysql是由SQL接口,解析器,优化器, ...
随机推荐
- Linux 学习目录
1 VIM 快捷键
- [UE4]抓取准备
一.引擎的VR实例工程是使用手柄进行抓取的.我们需要加上可以使用鼠标进行抓取操作. 二.将左右手保存到全局变量. 三.左右手分别调用抓取和扔方法
- iOS XML解析使用-韩国庆
欢迎-------(北京-iOS移动开发金牌教师QQ:2592675215)韩老师给你带来XML解析课程 今天给大家讲解下xml解析的第三方简单用法:首先我解释下,json和xml解析格式. JSON ...
- New Journey--工作五年所思所感小记
正式参加工作满五年了,2013年7月9日走入游戏行业.之前就计划着应该提笔写点什么留下来,但当日子真的到了,竟是不知说些什么了.14年年中的时候我曾写过一篇工作一年的总结,现在回头读起来,还真是别有一 ...
- intellij idea 相关设置
IDEA这么高端的工具之前只是断断续续使用了一下,因为项目的开发都是在eclipse上,每次学习IDEA的使用都得上网搜索半天,今天自己整理一下,方便以后查阅. IDEA版本15.0.4 字体 界面字 ...
- Jmeter使用插件监控服务器资源的使用情况
环境准备 客户端: 1)安装最新版的Jmeter,目前为 Jmeter5.0 2)安装插件管理器:JMeterPlugin jmeter-plugins-manager.jar下载完成之后,将下载的j ...
- iis7.5 配置伪静态
1)首先新建一个应用程序池,名称任意,比如:nettest,托管管道模式先暂时设置为集成模式,等下面的一系列设置完成之后再设置成经典模式: 2)部署好站点,并将此站点的应用程序池设置为nettest; ...
- 【C语言基础】变量
1.什么是变量? 变量的本质就是内存中一段储存空间 2.变量为什么必须初始化? 所谓初始化就是赋值的意思 3.如何定义变量 数据类型 变量名 = 要赋的值 举例子: int i = 3:等价于 int ...
- Spring-表达式语言
概念及作用 Spring表达式语言全称为“Spring Expression Language”,缩写为“SPEL”,类似于Struts2x中使用的OGNL表达式语言,能在运行时构建复杂表达式.存取对 ...
- 使用Dom4j对XML文档创建与解析
创建XML文件: public class Dom4jCreateXml { public void testCreatXml() { //创建文档对象 Document document = Doc ...