6.1 innoDb逻辑存储结构和架构-简介
InnoDB 是 MySQL 默认的存储引擎,以其强大的事务支持、崩溃恢复能力和高效的数据处理能力广受欢迎。本文从逻辑存储结构、内存架构、磁盘结构到后台线程,逐步剖析 InnoDB 的关键概念,帮助您更好地理解和应用。
1. 逻辑存储结构
InnoDB 的数据存储采用多层次的逻辑结构,具有极高的组织性和扩展性。
- 表空间(Tablespace):InnoDB 数据存储的最高层次,负责组织数据文件。
- 段(Segment):表空间的子单位,分为数据段(存储表数据)、索引段(存储索引)和回滚段。
- 区(Extent):每个段由多个区组成,每个区包含 64 个连续的页(Page)。
- 页(Page):InnoDB 数据存储的基本单位,默认大小为 16KB。
- 行(Row):页中实际存储的记录数据。
1.1 特点:
- 分层结构使得数据管理更高效。
- 页大小支持调整(4KB、8KB、16KB),以适应不同场景的需求。
1.2 逻辑存储结构图
2. 内存架构
内存架构是 InnoDB 高性能的核心部分。以下是主要组成部分及其作用:
2.1 缓冲池(Buffer Pool)
- 简介:缓冲池是用于缓存表数据和索引的区域,占用 InnoDB 的大部分内存。
- 作用:
- 减少磁盘 I/O:将数据和索引页缓存在内存中,减少磁盘读写。
- 脏页管理:修改后的页(脏页)被延迟写回磁盘,提高性能。
优化建议:
-
合理设置缓冲池大小(
innodb_buffer_pool_size
)。 -
查看缓冲池命中率:
SHOW ENGINE INNODB STATUS;
2.2 更改缓冲区(Change Buffer)
- 简介:缓存对非唯一二级索引的修改操作,减少随机写磁盘的次数。
- 作用:
- 延迟写入:对二级索引的插入、更新和删除操作先缓存在更改缓冲区,后续批量写入磁盘。
- 提升性能:在写密集型场景下效果显著。
2.3 自适应哈希索引(Adaptive Hash Index)
- 简介:基于热点数据动态生成的哈希索引,用于加速等值查询。
- 作用:
- 提高 B+ 树索引的查询效率。
- 减少多层索引节点的遍历。
查询是否开启:
SHOW VARIABLES LIKE '%hash_index%';
2.4 日志缓存区
- 简介:存储事务日志的内存区域。
- 作用:
- 加速事务日志写入。
- 支持崩溃恢复。
查看相关参数:
SHOW VARIABLES LIKE '%log_buffer_size%';
SHOW VARIABLES LIKE '%flush_log%';
innodb_flush_log_at_trx_commit
值的含义:
1
:每次事务提交时立即写入磁盘,保证数据安全。0
:日志保存在内存中,性能高但数据不安全。2
:日志写入 OS 缓存,周期性刷盘,性能与安全性折中。
3. 磁盘结构
InnoDB 数据持久化依赖于磁盘结构,其设计确保了高效存储和事务一致性。
3.1 系统表空间
- 简介:存储共享元数据、Undo 数据、事务日志等。
- 作用:管理数据库的核心元数据。
查询指令:
SHOW VARIABLES LIKE '%innodb_data_file_path%';
3.2 独立表空间(File-Per-Table Tablespaces)
- 特点:每个表单独存储在一个
.ibd
文件中。 - 优点:
- 更灵活的备份和迁移。
- 减少单个表空间的碎片。
3.3 通用表空间
-
特点:支持多个表共享一个表空间。
-
指令:
-
创建表空间:
CREATE TABLESPACE ts1 ADD DATAFILE 'ts1.ibd' ENGINE=InnoDB;
-
表指定表空间:
CREATE TABLE employees (...) TABLESPACE ts1;
-
3.4 Undo 表空间
- 作用:存储回滚信息。
- 特点:在事务回滚和多版本并发控制(MVCC)中发挥重要作用。
3.5 临时表空间
- 简介:存储临时表的数据,仅在会话期间有效。
3.6 双写缓冲区
- 作用:防止写操作中断导致数据损坏。
- 机制:
- 数据页先写入双写缓冲区。
- 双写缓冲区再将数据写入表空间。
3.7 Redo Log 重做日志
- 作用:记录事务的物理变化,用于崩溃恢复。
- 组成:
- Redo Log Buffer:内存中的日志缓冲。
- Redo Log File:磁盘上的日志文件。
4. 后台线程
InnoDB 依靠多个后台线程管理内存、磁盘和事务。
4.1 Master Thread
- 作用:调度和执行主要后台任务,如脏页刷新和更改缓冲区合并。
4.2 IO Thread
- 作用:处理磁盘 I/O 请求。
- 分类:
类型 | 作用 | 默认线程数量 |
---|---|---|
Read Thread | 处理读请求(从缓冲池读取页) | 默认 4(可配置) |
Write Thread | 处理写请求(刷新脏页到磁盘) | 默认 4(可配置) |
Insert Buffer Thread | 合并插入缓冲区的更改 | 1 |
Log Thread | 刷新事务日志到磁盘 | 1 |
注:
- Read Thread 和 Write Thread:
- 数量:默认均为 4,负责处理 I/O 操作,适用于大规模的并发读写。
- 可配置参数 :
innodb_read_io_threads
:配置读线程数量。innodb_write_io_threads
:配置写线程数量。- 作用:这些线程负责从磁盘读取数据页(读线程)或将脏页写入磁盘(写线程)。
- Insert Buffer Thread:
- 数量:固定为 1,无法通过配置改变。
- 作用:在插入数据时,合并更改到二级索引的缓冲区。
- Log Thread:
- 数量:固定为 1。
- 作用:负责将事务日志从缓冲区刷新到磁盘文件(如 redo log 文件)。
- 优化机制:
- 使用了组提交(group commit),提高日志刷新效率。
查看引擎状态:
SHOW ENGINE INNODB STATUS;
4.3 Purge Thread
- 作用:清理不再需要的 Undo 数据,减少表空间占用。
4.4 Page Cleaner Thread
- 作用:刷新脏页到磁盘,减少事务提交时的延迟。
通过对 InnoDB 存储引擎的深入了解,可以更有效地优化 MySQL 数据库性能,提高系统的稳定性和可靠性。
相关文章:

6.1 innoDb逻辑存储结构和架构-简介
InnoDB 是 MySQL 默认的存储引擎,以其强大的事务支持、崩溃恢复能力和高效的数据处理能力广受欢迎。本文从逻辑存储结构、内存架构、磁盘结构到后台线程,逐步剖析 InnoDB 的关键概念,帮助您更好地理解和应用。 1. 逻辑存储结构 InnoDB 的数据…...
C++看懂并使用-----回调函数
一)回调函数的定义 在 C 中,回调函数是一段作为参数传递给其他函数的可执行代码。它允许在一个函数内部的特定点调用外部定义的函数,以实现更灵活的功能。 回调函数(Callback Function)是一种通过函数指针或函数对象&a…...

构建短视频矩阵生态体系开发分享
短视频矩阵系统模型的技术开发是一个综合性强、复杂度高的工程项目,它涵盖了广泛的技术选择与架构规划。以下是该项目开发过程中的关键步骤和核心考虑因素: 需求分析阶段: 明确目标用户群体及其需求,以确保系统设计的针对性和实…...

qt QGraphicsScale详解
1、概述 QGraphicsScale是Qt框架中提供的一个类,它提供了一种简单而灵活的方式在QGraphicsView框架中实现缩放变换。通过设置水平和垂直缩放因子、缩放中心点,可以创建各种缩放效果,提升用户界面的交互性和视觉吸引力。结合QPropertyAnimati…...

CAD 文件 批量转为PDF或批量打印
CAD 文件 批量转为PDF或批量打印,还是比较稳定的 1.需要本地安装CAD软件 2.通过 Everything 搜索工具搜索,DWG To PDF.pc3 ,获取到文件目录 ,替换到代码中, originalValue ACADPref.PrinterConfigPath \ r"C:…...
Java基础面试题16:简述Servlet的体系结构
Servlet 是 JavaEE 技术中的一大核心组件,它运行在服务器端,用于处理客户端的请求并生成响应。如果你想深入了解它的体系结构,下面会用通俗的语言带你一步步搞懂。 1. Servlet API:开发者和容器沟通的桥梁 Servlet API 是开发 S…...
Web开发基础学习——理解React组件中的根节点
Web开发基础学习系列文章目录 第一章 基础知识学习之理解React组件中的根节点 文章目录 Web开发基础学习系列文章目录前言一、根节点的概念二、示例解释总结 前言 在 React 应用中,根节点(Root Node)是指 React 组件树的起始点,…...
【人工智能】探索自然语言生成(NLG):用GPT生成文本
《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! 自然语言生成(Natural Language Generation, NLG)是自然语言处理(NLP)领域的重要分支,旨在生成符合语法和语义的自然语言文本。近年来,基于深度学习的生成式预训练模型(GPT)在NLG任务中取得了巨大…...

挑战用React封装100个组件【004】
项目地址 https://github.com/hismeyy/react-component-100 组件描述 组件适用于展示图片的地方,提供了small,medium,large三种大小。可以删除图片,也可以全屏预览图片。 样式展示 前置依赖 今天我们的这个挑战需要用用到了…...
vue elementui layout布局组件实现规则的弹性布局
背景:遇到在一个容器里,采用弹性盒布局的时候,如果元素个数改变,元素的排列会错乱。 解决方式 方式一:之前遇到的时候,是采用计算元素个数的方式,采用透明元素补齐的方式(比如一个有…...
SpringBoot Web 开发请求参数
SpringBoot Web 开发请求参数 简单的 web 请求: @RestController public class HelloController {@RequestMapping("sayHello")public String sayHello(){System.out.println("Hello World");return "hello world";} }获取请求参数 简单参数…...
python7学习笔记-循环、迭代、pass
九九乘法表-while循环 right 1 while right < 9:left 1while left < right:print(f{left}x{right}{left * right},end\t)left 1print()right 1 # #效果: #1x11 #1x22 2x24 #1x33 2x36 3x39 #1x44 2x48 3x412 4x416 #1x55 2x510 3x515 4x520 5x525 #…...

LeetCode78:子集
链接:78. 子集 假设我们要求[1, 2, 3]的子集: 我们知道[1, 2]的子集是A: 而[1, 2, 3]就是比[1, 2]多了一个元素3;所以将3加入到上述A中的每个集合中,得到一个新集合B: 结论:[1, 2, 3]的子集就…...

Linux 安装scala
文章目录 Linux 安装scala下载环境变量配置 Linux 安装scala 前提linux需要已经安装好JDK(JDK安装),Scala对JDK版本有明确的要求。通常,Scala的稳定版本要求JDK版本不低于1.8。例如,Scala 2.11.8和2.12.7版本都要求JD…...

重生之我在异世界学编程之C语言:深入指针篇(上)
大家好,这里是小编的博客频道 小编的博客:就爱学编程 很高兴在CSDN这个大家庭与大家相识,希望能在这里与大家共同进步,共同收获更好的自己!!! 本文目录 引言正文(1)内置数…...

linux centos7 yum命令失效
linux centos7 yum命令失效 Centos7使用yum命令失效,报错:Could not retrieve mirrorlist http://mirrorlist.centos.org/?release7&archx86_64&repoos&infrastock error was 14: curl#6 - “Could not resolve host: mirrorlist.centos.or…...

mac访达打开终端
选择文件夹打开 选中文件夹,然后右键即可: 在当前文件夹打开 在访达的当前文件夹长按option键 左下角出现当前文件夹路径 右键即可打开终端...
【MySQL 进阶之路】索引的使用
5.索引的使用规则 在数据库管理系统(DBMS)中,索引是提高查询效率的关键机制之一。MySQL索引优化是指通过设计、调整和选择合适的索引策略,以提高数据库的查询性能和降低资源消耗。以下是一些关键的索引使用规则: 1. …...

网络编程相关 API 学习
目录 1. 网络编程中的基本概念 2. UDP 的 socket api 的使用 (1) DatagramSocket API (2) DatagramPacket API (3) InetSocketAddress API (4) 使用 UDP 的 socket api 3. TCP 的 socket api 的使用 (1) ServerSocket API (2) Socket API 1. 网络编程中的基本概念 客…...

python使用python-docx处理word
文章目录 一、python-docx简介二、基本使用1、新建与保存word2、写入Word(1)打开文档(2)添加标题(3)添加段落(4)添加文字块(5)添加图片(6…...

深度学习在微纳光子学中的应用
深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向: 逆向设计 通过神经网络快速预测微纳结构的光学响应,替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…...

家政维修平台实战20:权限设计
目录 1 获取工人信息2 搭建工人入口3 权限判断总结 目前我们已经搭建好了基础的用户体系,主要是分成几个表,用户表我们是记录用户的基础信息,包括手机、昵称、头像。而工人和员工各有各的表。那么就有一个问题,不同的角色…...
oracle与MySQL数据库之间数据同步的技术要点
Oracle与MySQL数据库之间的数据同步是一个涉及多个技术要点的复杂任务。由于Oracle和MySQL的架构差异,它们的数据同步要求既要保持数据的准确性和一致性,又要处理好性能问题。以下是一些主要的技术要点: 数据结构差异 数据类型差异ÿ…...
使用van-uploader 的UI组件,结合vue2如何实现图片上传组件的封装
以下是基于 vant-ui(适配 Vue2 版本 )实现截图中照片上传预览、删除功能,并封装成可复用组件的完整代码,包含样式和逻辑实现,可直接在 Vue2 项目中使用: 1. 封装的图片上传组件 ImageUploader.vue <te…...
2023赣州旅游投资集团
单选题 1.“不登高山,不知天之高也;不临深溪,不知地之厚也。”这句话说明_____。 A、人的意识具有创造性 B、人的认识是独立于实践之外的 C、实践在认识过程中具有决定作用 D、人的一切知识都是从直接经验中获得的 参考答案: C 本题解…...

算法:模拟
1.替换所有的问号 1576. 替换所有的问号 - 力扣(LeetCode) 遍历字符串:通过外层循环逐一检查每个字符。遇到 ? 时处理: 内层循环遍历小写字母(a 到 z)。对每个字母检查是否满足: 与…...

Python Ovito统计金刚石结构数量
大家好,我是小马老师。 本文介绍python ovito方法统计金刚石结构的方法。 Ovito Identify diamond structure命令可以识别和统计金刚石结构,但是无法直接输出结构的变化情况。 本文使用python调用ovito包的方法,可以持续统计各步的金刚石结构,具体代码如下: from ovito…...
C++课设:简易日历程序(支持传统节假日 + 二十四节气 + 个人纪念日管理)
名人说:路漫漫其修远兮,吾将上下而求索。—— 屈原《离骚》 创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊) 专栏介绍:《编程项目实战》 目录 一、为什么要开发一个日历程序?1. 深入理解时间算法2. 练习面向对象设计3. 学习数据结构应用二、核心算法深度解析…...

解读《网络安全法》最新修订,把握网络安全新趋势
《网络安全法》自2017年施行以来,在维护网络空间安全方面发挥了重要作用。但随着网络环境的日益复杂,网络攻击、数据泄露等事件频发,现行法律已难以完全适应新的风险挑战。 2025年3月28日,国家网信办会同相关部门起草了《网络安全…...
深度学习之模型压缩三驾马车:模型剪枝、模型量化、知识蒸馏
一、引言 在深度学习中,我们训练出的神经网络往往非常庞大(比如像 ResNet、YOLOv8、Vision Transformer),虽然精度很高,但“太重”了,运行起来很慢,占用内存大,不适合部署到手机、摄…...