进阶篇07——InnoDB引擎介绍

概览

逻辑存储结构

架构

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

内存结构 

 

磁盘结构

后台线程

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

事务原理

基本概念

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.mzph.cn/diannao/35216.shtml

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

相关文章

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

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

Vue介绍与入门(一篇入门)

Vue.js 是一个流行的 JavaScript 框架,专门用于构建用户界面和单页面应用程序。它简单易学,但功能强大,能够帮助开发者快速构建交互性强的 Web 应用。 本教程旨在帮助那些刚开始学习 Vue.js 的开发者快速入门,并掌握一些基础知识…

【UE5.1 角色练习】12-坐骑——Part2(让角色骑上坐骑)

目录 前言 效果 步骤 一、坐骑的父类 二、将角色附加到坐骑 三、添加坐姿 四、骑上坐骑 五、从坐骑上下来 前言 在上一篇(【UE5.1 角色练习】11-坐骑——Part1(控制大象移动))基础上继续实现角色骑上坐骑的功能。 效果 …

语言的数据结构:树与二叉树(二叉树篇)

语言的数据结构:树与二叉树(二叉树篇) 前言概念特别的二叉树满二叉树完全二叉树 存储结构顺序存储链式存储 查找方式 前言 上文说到了树,有人认为二叉树是树的每一个分支都有两个子节点。其实这也对。但二叉树在此基础上还做了限…

RS422串口通信协议介绍和基础代码实现

**RS-422串口协议介绍**RS-422是一种工业标准的通信接口,其全称是“平衡电压数字接口电路的电气特性”。它是在RS-232的基础上发展而来,旨在解决RS-232通信距离短和速率低的缺点。以下是对RS-422串口协议的详细介绍:传输速率与距离&#xff1…

MyCAT 2 简单入门

MyCAT 2 基础 什么是 MyCAT 2? MyCAT 2 是一款开源的数据库中间件,它主要用于解决数据库的分库分表、读写分离等问题。MyCAT 2 基于 MyCAT 1 的架构进行优化和重构,具有更高的性能和稳定性,支持多种数据库类型,包括 …

【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…

《mysql篇》--mysql常用命令

数据库操作 显示当前数据库 show databases;(database 后面要加s) 这行命令用来显示当前有多少个数据库 //mysql中有自带的四个库 创建数据库 create database 数据库名(name); 创建一个数据库 create dabase if not exists <数据库名(name)>; //如果系统有与当前创建…

前端vite+vue3——利用环境变量和路由区分h5、pc模块打包(从0到1)

⭐前言 大家好&#xff0c;我是yma16&#xff0c;本文分享 前端vitevue3——利用环境变量和路由对前端区分h5和pc模块打包&#xff08;从0到1&#xff09;。 背景&#xff1a; 前端本地开发pc和h5的项目&#xff0c;发布时需要区分开h5和pc的页面 vite Vite 通过在一开始将应…

图片怎么加水印?快来试试这6个图片加水印方法(2024年新)

图片怎么加水印&#xff1f;作为打工人在日常的工作生活中总会遇到各种各样的工作难题&#xff0c;相信从事电商或者是设计等工作的小伙伴们&#xff0c;遇到最多的问题应该就是给图片添加水印了。为什么要给图片加水印&#xff1f;其实给图片加水印最主要的目的是保护我们的图…

刷题——二叉树的中序遍历

双指针法 void midorder(vector<int>&res, TreeNode* root){if(root NULL) return;midorder(res, root->left);res.push_back(root->val);midorder(res, root->right);}vector<int> inorderTraversal(TreeNode* root) {// write code herevector<…

代码随想录算法训练营第四十九天|LeetCode300 最长递增子序列、LeetCode674 最长连续递增序列、LeetCode718 最长重复子数组

题1&#xff1a; 指路&#xff1a;300. 最长递增子序列 - 力扣&#xff08;LeetCode&#xff09; 思路与代码&#xff1a; 求最长递增子序列&#xff0c;那么就定义一个数组dp[i]&#xff0c;含义为最长递增子序列。这里有一个小问题&#xff0c;这里的序列的范围为何。如果…

一文入门Makefile

今天我们来玩玩Makefile。 这边是借鉴的陈皓老师的《跟我一起写 Makefile》 pdf下载链接如下。 链接&#xff1a;https://pan.baidu.com/s/1woRq2nEkgzLv1o5uE0FZHg?pwdmhrh 提取码&#xff1a;mhrh 我们之前已经算是入门了gcc&#xff0c;那我们的下一站就是Makefile&…

http和https请求总结

http请求是不安全的请求的端口是80&#xff0c;https请求是安全的请求的端口是443 但是请求安全也不是绝对的。 要想先了解https就的先说几个概念 1、证书 2、加密算法 openssl TLS/SSL 3、协议x509协议 http传输数据都是明文&#xff0c;在数据传输的过程会经过很长的链路…

C#面: 能够将非静态的方法覆写成静态方法吗?

在C#中&#xff0c;不能将非静态方法覆写成静态方法。这是因为静态方法是属于类的&#xff0c;而非静态方法是属于类的实例的。覆写&#xff08;重写&#xff09;是指在派生类中重新实现基类中的虚方法或抽象方法&#xff0c;以改变其行为。而静态方法是无法被派生类所继承的&a…

嵌入式学习(Day 51:ARM指令/汇编与c语言函数相互调用)

1.Supervisor模式与SVC模式 Supervisor模式是ARM处理器的一个特权工作模式&#xff0c;允许执行特权指令和访问特权资源。SVC模式&#xff08;Supervisor Call&#xff09;是与Supervisor模式相关的一个功能或指令&#xff0c;用于从用户模式切换到Supervisor模式&#xff0c;…

1、Redis系列-Redis高性能原理详解

Redis高性能原理详解 Redis是一款高性能的内存数据库&#xff0c;广泛应用于需要快速读写访问的数据密集型应用中。它的高性能得益于多方面的设计和优化。以下是Redis高性能实现的详细解释&#xff1a; 1. 单线程架构 Redis采用单线程架构来处理客户端请求&#xff0c;这与传…

服务器流量收发测试-续篇

文章目录 一、概述二、普通java工程1&#xff0c;pom文件2&#xff0c; 定时任务3&#xff0c;打包4&#xff0c;jar运行 三、打包docker镜像1&#xff0c;镜像打包配置docker环境&#xff1a;2&#xff0c;连接远程镜像仓库 四、部署运行1. 容器运行2. 单容器多次运行jar3. 容…

大模型应用研发基础环境配置(Miniconda、Python、Jupyter Lab、Ollama等)

老牛同学之前使用的MacBook Pro电脑配置有点旧&#xff08;2015 年生产&#xff09;&#xff0c;跑大模型感觉有点吃力&#xff0c;操作起来有点卡顿&#xff0c;因此不得已捡起了尘封了快两年的MateBook Pro电脑&#xff08;老牛同学其实不太喜欢用 Windows 电脑做研发工作&am…

04_记录锁

记录锁&#xff08;Record Lock&#xff09; 文章目录 记录锁&#xff08;Record Lock&#xff09;简介原理加锁流程锁类型使用场景示例与其他锁的对比结论 简介 MySQL 中的记录锁&#xff08;Record Lock&#xff09;是行级锁的一种&#xff0c;用于锁定数据库表中的特定行。…