进阶篇07——InnoDB引擎介绍

news2025/1/13 16:58:56

概览

逻辑存储结构

架构

当执行增删改查操作时,操作的是缓冲区的数据,如果缓冲区里没有要操作的数据,就会从磁盘中读取数据加载到缓冲区中;缓冲区的数据会以一定的频率通过后台线程刷新到磁盘中永久存储。

内存结构 

 

磁盘结构

后台线程

后台线程的作用就是在合适的时机将内存缓冲池的数据刷新到磁盘文件当中

事务原理

基本概念

redo.log日志

解决事务的持久性

当客户端执行增删改操作时,就会去操作缓冲池中的数据(如果此时缓冲池没有所需要的数据,就会去磁盘文件中加载需要的数据到缓冲池里),然后对相应的数据页进行更改。缓冲池的某些数据页被更改后,和磁盘里存储的数据就不一致了,缓冲池里这些被修改的数据页就称为脏页。在一定的时机里,会通过后台线程将脏页的数据刷新到磁盘中进行永久化存储,但是这个刷新的过程可能会出错,那么更改的数据就会丢失,但在客户端提交事务时,就已经在更改缓冲池的数据之后告知客户端更改完成,这时候就出现了问题。而redo.log就是解决这个问题的。在客户端进行增删改时,会对缓冲池中的数据页进行增删改操作,在操作之后会将更改过的数据页即脏页立即刷新到redo log buffer中,在客户端提交事务之后,立即将redo log buffer中的脏页数据刷新到磁盘中的redo.log日志文件中,这样当后台线程将缓冲池中的数据刷新到磁盘出错时,就可以用redo.log中的数据进行数据恢复

为什么每一次提交事务的时候,要把数据刷新到redo log buffer中,而不是直接将buffer pool中的脏页刷新到磁盘中?这是因为直接将buffer pool中的数据刷新到磁盘中,存在严重的性能问题;在执行增删改操作时,所操作的数据在磁盘中的位置都是随机的,就涉及到了大量的随机磁盘IO,性能就比较低。而redo log buffer通过异步IO将数据刷新到磁盘中的redo.log日志文件中,日志文件都是在文件末尾追加数据的,此时就是顺序磁盘IO,性能就高于随机磁盘IO。

如果脏页中的数据已经顺利的刷新到磁盘中的ibd文件里,此时redo.log中的数据就已经没有用了,因为数据已经存在ibd文件中了,所以每隔一段时间就回去清理redo.log中的数据

undo.log 日志

解决事务的原子性

有两个作用:一是在事务执行失败进行回滚时需要用到undo.log,还有一个用于就是MVCC多版本并发控制 

MVCC 多版本并发控制

基本概念

视频教程: 基本概念

实现原理

记录中的隐藏字段

undo.log 日志

readview

视频教程:readview

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1862410.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

H5、Vue3、UniApp实现抖音短视频功能

H5、Vue3、UniApp实现抖音短视频功能 ml-swiper https://ext.dcloud.net.cn/plugin?id18973 可 0 配置,高性能、低代码、全端兼容 APP端效果图 微信小程序端效果图 Vue网页端效果图 ml-swiper 可 0 配置,高性能、低代码、全端兼容 APP端效果图 …

基于Spring Boot+VUE职称评审管理系统

1管理员功能模块 管理员登录,通过填写注册时输入的用户名、密码、角色进行登录,如图1所示。 图1管理员登录界面图 管理员登录进入职称评审管理系统可以查看首页、个人中心、用户管理、评审员管理、省份管理、评审条件管理、职称申请管理、结果公布管理、…

昇思25天学习打卡营第2天|onereal》

今天学习内容是了解华为昇思平台。虽然打了卡,但是我的jupyter里面并没有播放按钮,所以还是无法运行代码。反映给昇思吴彦祖小哥了,他说需要专家帮我解决。 我还是要自我表扬一下,不懂就问,切莫不懂装懂,那…

【Linux】常用基本命令

wget网址用于直接从网上下载某个文件到服务器,当然也可以直接从网上先把东西下到本地然后用filezilla这个软件来传输到服务器上。 当遇到不会的命令时候,可以使用man “不会的命令”来查看这个命令的详细信息。比如我想要看看ls这个命令的详细用法&…

Opencv学习项目6——pyzbar

在之前我们学习了解码图片中的二维码,这次我们开启摄像头来解码视频中二维码 开启摄像头 # 打开摄像头 cap cv2.VideoCapture(0) cap.set(3, 640) # 设置摄像头画面宽度 cap.set(4, 480) # 设置摄像头画面高度 我使用的是笔记本上的摄像头来进行的,…

数据结构(Java):顺序表集合类ArrayList

1、线性表 线性表,在逻辑结构上是连续的(可理解为连续的一条直线,一对一的关系),而在物理结构上不一定连续,通常以数组和链式结构进行存储。 线性表是一种在实际中广泛使用的数据结构,常见的线…

【最佳实践】 使用react写一个sliderbar 侧滑导航组件

大家好,我是DX3906 我们现在使用React 来实现一个侧边导航组件(sidebar),你可以使用 CSS 和 React 的状态管理来实现。下面是一个简单的示例,展示如何创建一个基本的侧边导航组件: 1. 安装依赖:…

浅谈逻辑控制器之Include控制器

浅谈逻辑控制器之Include控制器 “Include控制器”是一个特别实用的功能,它允许用户将一个或多个测试片段(通常是请求)包含到不同的测试计划或模块中,从而实现代码的复用和测试结构的优化。本文档将详细介绍JMeter中的Include控制…

并发编程-02深入理解Java线程

一 线程基础知识 1.1 理解线程和进程 进程和线程的概念: 进程: 程序由指令和数据组成,但这些指令要运行,数据要读写,就必须将指令加载至CPU,数据加载至内存。在指令运行过程中还需要用到磁盘、网络等设备。进程就是用来加载指…

Gobject tutorial 十

参考:GLib – 2.0: The Main Event Loop The Main Event Loop 主事件循环管理所有可用的事件源,事件可以是各种类型、各种数量的。比如说文件描述符(普通文件、管道以及套接字)和超时。 新类型的事件源可以通过函数g_source_attach来添加。为了使多个…

输入/输出文字

自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm1001.2014.3001.5501 在海龟绘图中,也可以输入或者输出文字,下面分别进行介绍。 1 输出文字 输出文字可以使用write()方法来实现,语…

【QCustomPlot实战系列】QCPGraph区域高亮

使用QCPDataSelection来设置选中的区域&#xff0c;并将QCPGraph的可选择区域设置成QCP::stMultipleDataRanges void AreaPieces::initCustomPlot(QCustomPlot *parentPlot) {QVector<double> x {0, 1, 2, 3, 4, 5, 6, 7, 8};QVector<double> y {200, 560, 750…

解决Vue+Vite打包后Leaflet的marker图标不显示的问题

前言 用Leaflet写关于WebGIS的开发&#xff0c;用Vite或者webpack打包&#xff0c;打包后会找不到图标&#xff0c;如下所示。 直言的说&#xff0c;笔者去网上搜了搜&#xff0c;其实收到一个比较好是答案。网址如下。 &#xff08;完美解决~&#xff09;关于VueLeaflet添加…

P2实验室装修标准都有哪些

P2实验室&#xff08;也称为生物安全二级实验室&#xff0c;BSL-2实验室&#xff09;的装修标准需要满足一系列的设计和施工要求&#xff0c;以确保实验室的安全性和功能性。因此&#xff0c;P2实验室装修标准不仅要满足一般实验室的要求&#xff0c;还需符合生物安全的特殊规定…

企业运维六边形战士 质量稳定 效率为王

随着信息化的不断深入和扩展&#xff0c;企业IT系统的复杂性和设备多样性日益增加。为了保障业务的高可用性和连续性&#xff0c;企业需要一个全面、高效、智能的一体化运维管理平台。在用户市场的推动下&#xff0c;LinkSLA智能运维管家展现出【六边形战士】的优质属性&#x…

数据结构-----【链表:刷题】

-------------------------------------------基础题参照leetcode---------------------------------------------------------------------------------------------------------- 【2】两数相加 /*** Definition for singly-linked list.* struct ListNode {* int val;…

ChatBI开源实现: 基于SuperSonic的AI+BI的产品设计

产品起源 为什么要做这样的产品&#xff1f;文章《ChatBI开源实现: AIBI的产品设计》中有介绍 为什么要自己做这样的产品&#xff1f;1、低成本试错&#xff1b;2、未来数据生态入口&#xff1b; 为什么要基于Supersonic做&#xff1f; 开源协议友好&#xff1a;可魔改商用 社区…

仿真分析 + AI:创建基础设施的新未来

吴付标 大漠风电&#xff0c;深远海平台&#xff0c;一带一路上的高铁、电站…… 在新一轮的基础设施建设浪潮中&#xff0c;项目与结构变得越来越复杂&#xff0c;碳中和与可持续发展的要求越来越高&#xff0c;仿真分析技术应运而兴。 在最近召开的Bentley软件2024创新智旅 …

【Python/Pytorch - 网络模型】-- 高阶SVD算法

文章目录 文章目录 00 写在前面01 基于Python版本的高阶SVD算代码02 HOSVD 的步骤 00 写在前面 高阶奇异值分解&#xff08;Higher-Order SVD&#xff0c;HOSVD&#xff09;是一种将传统的奇异值分解&#xff08;SVD&#xff09;扩展到高阶张量的方法。它能够将一个高阶张量分…