了解MVCC

news/2024/10/22 11:43:27/

概念

MVCC,全称Multi-Version Concurrency Control,即多版本并发控制,是一种并发控制的方法,维护一个数据的多个版本,使得读写操作没有冲突,快照读为MySQL实现MVCC提供了一个非阻塞读功能。MVCC的具体实现还要依赖数据库记录中的三个隐式字段,undo log,readView。

当前读

读取的是记录的最新版本,读取时还要保证其他并发事务不能修改当前记录,会对读取的记录进行加锁。对于我们日常的操作,如:select...lock in share mode(共享锁),select... for update、update、insert、delete(排他锁)都是一种当前读。

快照读

简单的select(不加锁)就是快照读,快照读,读取的是记录数据的可见版本,有可能是历史数据,不加锁,是非阻塞读。
  Read Committed:每次select,都生成一个快照读。
  Repeatable Read:开启事务后第一个select语句才是快照读的地方。
  Serializable:快照读会退化为当前读。

ibd2sdi  ibd文件名  这条指令可以查看对应ibd文件中的信息。

undo log版本链

在执行修改操作前undo log会记录修改前的操作

执行修改后DB_TRX-ID和DB_ROLL_PTR都会进行相应的更新DB_TRX-ID更新为当前事务id DB_ROLL_PTR指向上一条记录在undo log中的存放地址

 readview

min_ids 当前还未提交的事务id集合

min_trx_id 最小活跃事务id

max_trx_id 预分配事务id 当前最大事务id+1 因为事务id是自增的

creater_trx_id ReadView创建时的事务id

trx_id代表当前修改记录的事务id

 当前隔离级别为RC

每执行一次快照读都会生成ReadView

这次读取的记录应该是DB_TRX-ID = 2 的数据

 这次读取的记录应该是DB_TRX-ID = 3 的数据

  当前隔离级别为RR

仅在事务第一次执行快照时生成ReadView后续复用

总结 

redo log保证了事务的持久性

undo log保证了事务的原子性

redo log+undo log保证了事务的一致性

MVCC+锁保证了事务的隔离性


http://www.ppmy.cn/news/1505360.html

相关文章

神经网络中学习率调整的不同方法

调整学习率是优化神经网络训练效果的关键步骤。以下是一些常见的方法和策略来调整学习率,以提高模型的训练效果: 1.选择合适的初始学习率 在模型训练开始时,选择一个适当的初始学习率非常重要。如果学习率太高,可能会导致训练不…

计算机是如何工作的

发展史 Java 最初诞生的时候,适用于“嵌入式开发” 后来给网页网页开发逻辑(Java 在进行前端开发),迎来第一波巅峰 后来被微软打压后寻出路,开始做服务器开发(后端开发)和嵌入式开发&#xff…

Python面试题:结合Python技术,如何使用Scikit-learn进行监督学习和无监督学习

使用Scikit-learn进行监督学习和无监督学习可以帮助我们构建和评估机器学习模型。下面将分别介绍如何使用Scikit-learn进行这两种类型的学习。 监督学习 监督学习需要训练数据的特征和目标标签。Scikit-learn提供了多种监督学习算法,如线性回归、决策树、支持向量…

【JVM基础12】——垃圾回收-说一下JVM有哪些垃圾回收器?

目录 1- 引言:垃圾回收器2- ⭐核心:垃圾回收器详解2-1 串行垃圾回收器2-2 并行垃圾回收器2-3 CMS(并发垃圾回收)——主要作用在老年代 3- 小结3-1 说一下JVM有哪些垃圾回收器? 1- 引言:垃圾回收器 在 JVM …

用Python打造精彩动画与视频,6.3 项目案例分析

6.3 项目案例分析 在这一节中,我们将通过具体的项目案例,深入探索 Manim 的潜力,并展示如何使用 Manim 创建复杂且富有表现力的动画。这些案例将涵盖数学、物理以及其他科学领域,帮助您更好地理解和应用 Manim。 6.3.1 案例一&a…

AI编程助手那些事儿

最近跟身边的程序员老杆子讨论需求时,惊奇的发现,他居然没使用AI编程助手。一时间有2个想法从大脑闪过,然后心里还带了一丝轻蔑: AI编程助手这么好的东西,你居然不用。作为老程序员,你居然不跟上时代步伐&…

CSS对元素的分类

文章目录 概述置换元素/非置换元素置换元素非置换元素 行内元素/块级元素/行内块级元素行内元素块级元素行内块级元素 概述 CSS从两个维度上将HTML元素进行了分类: 从元素内容的表现形式上,将元素分为:置换元素、非置换元素。从元素自身的显…

突破getimagesize()

在CTF(Capture The Flag)竞赛中,突破getimagesize()函数的限制是一种常见的技巧,用于绕过Web应用程序对上传文件的图像验证。getimagesize()是PHP中用于检查图像文件信息的一个函数,它被广泛用于Web应用中来验证上传的…