推广

Mysql – InnoDB架构

iseeyu2年前 (2024-02-21)推广103

image.png

二、简要说明

InnoDb架构划分为内存结构磁盘结构

1. 内存结构

1.1 buffer pool(缓冲池)

buffer pool是主存中的一个区域,InnoDB在访表和索引数据时在这里进行缓存。buffer pool允许直接从内存访问常用数据,从而提高处理速度。在专用服务器上,多达80%的物理内存通常分配给缓冲池。

更多关于buffer pool的信息可以参考 – Mysql – InnoDB – 理解buffer pool

1.2 change buffer(变更缓冲)

change buffer是一种特殊的数据结构,当二级索引页不在buffer poole中时,它将更改缓存到二级索引页。缓冲的更改(可能由INSERTUPDATEDELETE操作(DML)引起)稍后在其他读操作将页面加载到缓冲池时合并。

更多关于buffer pool的信息可以参考 – Mysql – InnoDB – 理解change buffer

1.3 adaptive hash index(自适应哈希索引)

自适应哈希索引使InnoDB能够在具有适当的工作负载组合缓冲池足够内存的系统上执行,更像内存中的数据库,而不会牺牲事务特性或可靠性。自适应哈希索引通过innodb_adaptive_hash_index变量启用,或者在服务器启动时通过——skip-innodb- adaptive_hash -index关闭。

详细介绍地址: 待续......

1.4 log buffer(日志缓冲)

log buffer区是存储要写入磁盘日志文件的数据的内存区域。log buffer大小由innodb_log_buffer_size变量定义。默认的大小是16MB。定期将log buffer的内容刷新到磁盘。大log buffer使大事务能够运行,而无需在事务提交之前将redo log数据写入磁盘。因此,如果您有更新、插入或删除许多行的事务,那么增加log buffer的大小可以节省磁盘I/O。

详细介绍地址: 待续......

2. 磁盘结构

2.1 tables

详细介绍地址: 待续......

2.2 indexes

详细介绍地址: 待续......

2.3 tablespace(表空间)

表空间包含了系统表空间独立表空间通用表空间临时表空间以及undo表空间

2.3.1 系统表空间:

a、系统表空间主要是change buffer的存储区域;

b、如果表是在系统表空间中创建的而不是在独立表空间或者通用表空间中创建的,那么系统表空间中也存储创建的表和索引数据;

c、在mysql8.0版本之前,mysql数据字典也存储在系统表空间之中,不过8.0版本之后,mysql合并了一个事务性数据字典,元数据存储在数据字典中;

d、在MySQL 8.0.20之前,double write buffer存储区域位于InnoDB系统表空间中。从MySQL 8.0.20开始,double write buffer存储区域位于double write文件中;

详细介绍地址: 待续......

2.3.2 独立表空间

独立表空间中包含了innoDb表的数据和索引信息,存放在单个的独立表空间文件

详细介绍地址: 待续......

2.3.3 通用表空间

通用表空间是指使用CREATE tablespace语法创建的共享InnoDB表空间

详细介绍地址: 待续......

2.3.4 临时表空间

innoDb中使用临时表空间分为session临时表空间global临时表空间

详细介绍地址: 待续......

2.3.5 undo表空间

Undo表空间包含Undo logUndo log是记录的集合,这些记录包含关于如何撤销事务对聚集索引记录的最新更改的信息。

详细介绍地址: 待续......

2.4 double write buffer

double write buffer是一个存储区域,InnoDB在将页面写到InnoDB数据文件中的适当位置之前,在这个存储区域中写入从buffer pool中刷新的页面。如果在页写过程中出现了操作系统、存储子系统或意外的mysqld进程退出,InnoDB可以在崩溃恢复期间从double write buffer中找到一个好的页副本。

虽然数据被写入两次,但double write buffer并不需要两倍的I/O开销或两倍的I/O操作。数据在一个大的顺序块中写入doublewrite缓冲区,通过对操作系统的单个fsync()调用(除非innodb_flush_method设置为O_DIRECT_NO_FSYNC)。

MySQL 8.0.20之前,double write buffer存储区域位于InnoDB系统表空间中。从MySQL 8.0.20开始,double write buffer存储区域位于double write文件中。

详细介绍地址: 待续......

2.5 redo log(重做日志)

redo log是一种基于磁盘的数据结构,在崩溃恢复期间用于纠正不完整事务写入的数据。在正常操作过程中,redo log对SQL语句或低级API调用产生的表数据更改请求进行编码。在意外关闭之前未完成数据文件更新的修改将在初始化期间和接受连接之前自动重播。关于redo log在崩溃恢复中的作用,请参见15.18.2节“InnoDB恢复”

默认情况下,redo log在物理上由两个名为ib_logfile0ib_logfile1的文件表示。MySQL以循环的方式写入redo log文件。redo log中的数据按照受影响的记录进行编码;这些数据统称为重做。数据通过redo log的通道由不断增加的LSN值表示。

详细介绍地址: 待续......

2.6 undo logs

undo log是与单个读写事务相关联的undo log记录的集合。undo记录包含关于如何撤销事务对聚集索引记录的最新更改的信息。

详细介绍地址: 待续......

未完待续......

扫描二维码推送至手机访问。

版权声明:本文由西安泽虎代运营发布,如需转载请注明出处。

转载请注明出处https://www.0291.com.cn/post/57563.html

相关文章

详解淘宝店铺的运营思路和操作玩法,教你如何

详解淘宝店铺的运营思路和操作玩法,教你如何

对于现阶段来说,应一些朋友们的反馈,想要在现有情况和困境下做出突破,方法固然有,但不代表着可以轻松执行。就像我们虽然可以把很多问题清楚的表达出来,但解决问题的道路会比较漫长和艰难。 想要突破,说简单也简单,说困难也困难,毕竟困难是相对的,要看是处于哪种市场环境、操作环境、运营思路、优化手段等。选择...

电商退位,私域让商家站在舞台中心

电商退位,私域让商家站在舞台中心

语:流量红利不再,传统电商遇瓶颈,获客成本遇难,品牌方纷纷开启新电商时代,聚集自己的私域池。电商平台退位,品牌转向私域发展,本文对新的电商趋势进行分析,并思考未来电商会朝着什么方向发展? 前几天,一个做私域的朋友给我分享了他们公司双十一的数据:30个社群,平均每个社群200人,...

鹿班如何制作主图(鹿班设计入口在哪里)

鹿班如何制作主图(鹿班设计入口在哪里)

目前的展示逻辑是系统抓取后千人千面展示。简单理解就是系统会结合消费者的购物和搜索记录,推送关联性较强的商品。当然系统推送时也会参考商品和店铺的综合竞争力择优推送。...

拼多多个人资料怎么改

拼多多个人资料怎么改

随着拼多多在我国电商市场的崛起,越来越多的用户选择在这个平台上购物、销售。而对于拼多多的个人资料修改,你是否感到困惑?别担心,今天我将为你揭秘拼多多个人资料怎么改,让你轻松搞定! 一、拼多多个人资料修改的重要性 在拼多多平台上,个人资料的完善程度直接影响到购物体验和信誉度。所以,学...

百度零位置排名,如何利用其快速获得精准流量。

百度零位置排名,如何利用其快速获得精准流量。

虽然,这个搜索结果仍然在百度自然排名中的十个搜索结果之一,但我们仍然将其称为搜索结果零位置排名。 理由非常简单:它会在搜索结果中,直接给出相应的答案。 重点是: 它有的时候并不需要你网站具有较高的权重。 它通常只是页面收录就会被快速展现。 它匹配的关键词是相当...

淘宝如何进行商品标题优化(淘宝运营标题优化技巧)

淘宝如何进行商品标题优化(淘宝运营标题优化技巧)

在宝贝的主图或者是详情页应该明确的写出相关的描述内容和标题对应,不然的话很容易会造成属性不一致,最后就会引起群众受影响。...

现在,非常期待与您的又一次邂逅

我们努力让每一部企业宣传片和抖音短视频成为商业大片