MySQL技术内幕:InnoDB存储引擎

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: MySQL技术内幕:InnoDB存储引擎

InnoDB存储引擎概述

InnoDB是事务安全的MySQL存储引擎,是OLTP应用的首选的存储引擎,一个新的OLTP项目需要快速的进行数据处理和快速对数据处理的结果进行返回,在这样的应用中我们往往需要保证操作的完成性,InnoDB引擎是很好的选择。

InnoDB体系架构

下图为InnoDb的体系架构,InnoDB存储引擎有多个内存块,这些内存块组成了一个容量不小的内存池,该内存池的作用如下:

1、维护所有进程、线程需要访问的内部数据结构。

2、缓存磁盘上的数据方便快速读取,在对磁盘数据修改之前在这里进行缓存。

3、重做日志缓冲。

后台线程的主要作用有三个:

1、刷新内存池中的数据,保证缓冲池中的内存的是最近的数据。

2、将已修改缓存中的数据内容刷新到磁盘文件。

3、保证在数据库发生异常的情况下InnoDB可以恢复到正常的运行状态。

后台进程

InnoDB存储引擎是多线程模型,后台中有多个不同的后台线程,处理不同的任务

Master Thread

主线程是一个非常核心的后台线程,主要负责:

1、将缓冲池的数据异步刷新到磁盘,保证数据的一致性

2、脏页的刷新

3、合并插入缓冲

4、UNDO页的回收

IO Thread

什么是AIO(Async IO)?

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2天前
|
存储 缓存 关系型数据库
MySQL 存储引擎
MySQL 存储引擎
19 6
|
1月前
|
存储 关系型数据库 MySQL
MySQL InnoDB数据存储结构
MySQL InnoDB数据存储结构
|
1月前
|
存储 缓存 关系型数据库
MySQL的varchar水真的太深了——InnoDB记录存储结构
varchar(M) 能存多少个字符,为什么提示最大16383?innodb怎么知道varchar真正有多长?记录为NULL,innodb如何处理?某个列数据占用的字节数非常多怎么办?影响每行实际可用空间的因素有哪些?本篇围绕innodb默认行格式dynamic来说说原理。
835 6
MySQL的varchar水真的太深了——InnoDB记录存储结构
|
16天前
|
存储 关系型数据库 MySQL
MySQL引擎对决:深入解析MyISAM和InnoDB的区别
MySQL引擎对决:深入解析MyISAM和InnoDB的区别
31 0
|
18天前
|
存储 缓存 关系型数据库
mysql存储引擎
mysql存储引擎
|
4天前
|
SQL 存储 关系型数据库
MySQL Cluster集群安装及使用
MySQL Cluster集群安装及使用
|
19天前
|
关系型数据库 MySQL 数据库
mysql卸载、下载、安装(window版本)
mysql卸载、下载、安装(window版本)
|
8天前
|
关系型数据库 MySQL 数据库
《MySQL 简易速速上手小册》第1章:MySQL 基础和安装(2024 最新版)
《MySQL 简易速速上手小册》第1章:MySQL 基础和安装(2024 最新版)
33 4
|
1月前
|
Ubuntu 关系型数据库 MySQL
Ubuntu 中apt 安装MySQL数据库
Ubuntu 中apt 安装MySQL数据库
69 0
|
2天前
|
关系型数据库 MySQL 数据安全/隐私保护
安装mysql和远程连接
安装mysql和远程连接
12 0