当前位置: 首页 > news >正文

mysql数据库之innodb存储引擎架构之内存架构

一、逻辑存储结构

mysql5.5版本开始,默认使用innodb存储引擎,它擅长事务处理,具有崩溃恢复特性,在日常开发中使用非常广泛。

架构图(左侧为内存架构,右侧为磁盘架构

二、 内存架构。

1、缓冲池

2、更改缓冲区(针对于非唯一二级索引页)

 3、自适应hash索引

 开启状态

 4、日志缓冲区

 查看缓冲区大小,默认大小

 日志刷新到磁盘时机,默认

 三、磁盘架构。

1、系统表空间

参数:存放的就是系统表空间

 

 2、独立表空间

 默认开启:每一张表都会生成一个对应的表空间文件

 3、通用表空间。

 创建表空间

 4、撤销表空间

 5、临时表空间

6、双写缓冲区和重做日志

 四、后台线程。

后台线程 

 1、master thread

核心后台线程,负责调度其他线程,还负责将缓冲池中的数据异步刷新到磁盘中,保持数据的一致性,还包括脏页的刷新,合并插入缓存、undo页的回收。

2、io thread

在innodb存储引擎中大量使用了aio来处理io请求,这样可以极大地提高数据库的性能,而io thread主要负责这些io请求的回调。

线程类型默认个数职责
read thread4负责读操作
write thread4负责写操作
log thread1负责将日志缓冲区刷新到磁盘
insert buffer thread1负责将写缓冲区内容刷新到磁盘

 查看innodb引擎状态信息:show engine innodb status。

 3、purge thread

主要用于回收事务已经提交了的undo log,在事务提交之后,undo log可能不用了,就用它来回收。

4、page cleaner thread

协助master thread刷新脏页到磁盘的线程,它可以减轻master thread的工作压力,减少阻塞。

http://www.lryc.cn/news/37353.html

相关文章:

  • Vue:(三十五)路由vue-router
  • Dynabook笔记本电脑无法开机怎么重装新系统?
  • React Native基础知识点
  • nginx 平滑升级
  • 数据结构——链表OJ题目讲解(2)
  • GitHub上线重量级分布式事务笔记,再也不怕面试官问分布式了
  • C++语法规则1(C++面向对象 )
  • Web漏洞-CSRF漏洞
  • Python3-面向对象
  • 拐点!新能源车交付均价首次「低于」燃油车,智能电动成新爆点
  • JavaScript String 字符串对象实例合集
  • 实习生培养计划
  • 【服务器管理】Wordpress服务器内存占用太高(优化方案详解)
  • 【ECCV 2022】76小时动捕,最大规模数字人多模态数据集开源
  • 联合解决方案 | 亚信科技AntDB数据库携手浪潮K1 Power赋能关键行业数字化转型,助力新基建
  • Android 单元测试问题总结(Robolectric+JUnit)
  • 专项攻克——二叉树
  • PACS系统源码 PACS源码 三维重建PACS源码
  • 利用Mysql存储过程造百万级数据
  • Vue2组件之间的传值通信
  • Spring Boot官方例子《Developing Your First Spring Boot Application》无法运行
  • 数据结构(3)— 线性表之顺序存储详解介绍(含代码)
  • ChatGPT正当时,让我们一起深耕智能内容生成和智能内容增强领域
  • 天梯赛训练L1-019 (谁先倒)
  • MySQL DQL语句基础(一)
  • ccc-pytorch-LSTM(8)
  • 教育小程序开发解决方案
  • 动态规划之股票问题大总结
  • 我来跟你讲vue进阶
  • #847(Div3)E. Vlad and a Pair of Numbers