mvcc 速读
MVCC(Multi-Version Concurrency Control,多版本并发控制)是MySQL中一种用于实现数据库并发控制的方法,尤其在InnoDB存储引擎中得到了广泛应用。它的主要作用是提高数据库在高并发场景下的性能,并确保数据的一致性。
以下是对MySQL MVCC的详细解释:
原理
MVCC通过保存数据的多个版本来管理并发事务。这些版本是通过在每次事务操作(插入、更新、删除)时创建的新数据快照实现的。这样,不同事务在读取同一数据时,可以看到不同的数据版本,从而避免了读写锁的竞争。
关键技术点
-
隐藏列:
- 每个记录除了用户定义的字段外,还包含两个额外的隐藏列:
trx_id
和roll_pointer
。其中,trx_id
记录插入或最后一次更新该记录的事务ID,而roll_pointer
指向该记录的上一个版本。
- 每个记录除了用户定义的字段外,还包含两个额外的隐藏列:
-
快照读:
- 快照读(Snapshot Read)是指通过MVCC机制读取数据的方式。事务开始时,会记录当前的系统版本号(也称为Read View)。在读取数据时,只会读取版本号小于或等于Read View版本号的数据,确保读到的数据是一致的。
-
当前读:
- 当前读(Current Read)是指读取最新的数据并加锁。例如,
SELECT ... FOR UPDATE
或UPDATE
操作。当前读需要获取最新的数据版本,并对读取的数据加锁,以防止其他事务的并发修改。
- 当前读(Current Read)是指读取最新的数据并加锁。例如,
-
版本链:
- 每条记录通过
roll_pointer
形成一个版本链。最新的记录指向上一个版本,依次类推。这样在执行回滚操作时,可以通过版本链找到对应的历史版本,实现数据的恢复。
- 每条记录通过
优点
-
提高并发性能:
- 由于MVCC避免了读写锁的直接竞争,提高了数据库在高并发场景下的性能。
-
事务隔离级别支持:
- MVCC主要支持读已提交(Read Committed)和可重复读(Repeatable Read)两种隔离级别,确保数据一致性的同时,提高了系统的吞吐量。
-
一致性视图:
- 每个事务在执行过程中看到的数据都是一致的,不会因为其他事务的修改而产生不一致的读。
缺点
-
空间开销:
- 多版本数据的维护需要额外的存储空间,尤其是对于频繁更新的表,历史版本的累积可能会导致空间占用增加。
-
复杂性增加:
- MVCC的实现增加了数据库系统的复杂性,需要更复杂的机制来管理多版本数据和垃圾回收。
通过以上机制,MVCC在保证数据一致性的前提下,提高了数据库的并发处理能力,是MySQL中非常重要的并发控制手段。
相关文章:
![](https://www.ngui.cc/images/no-images.jpg)
mvcc 速读
MVCC(Multi-Version Concurrency Control,多版本并发控制)是MySQL中一种用于实现数据库并发控制的方法,尤其在InnoDB存储引擎中得到了广泛应用。它的主要作用是提高数据库在高并发场景下的性能,并确保数据的一致性。 …...
![](https://img-blog.csdnimg.cn/50598b89cf3648d0b97471015e46892b.jpg)
美容仪维修过程记录
近期维修的家用射频美容仪,发一些维修过程的拆机图片...
![](https://i-blog.csdnimg.cn/direct/d680e547c21d4217b1f0f70561e18fc6.png#pic_center)
STM32入门开发操作记录(一)——新建工程
目录 一、课程准备1. 课程资料2. 配件清单3. 根目录 二、环境搭建三、新建工程1. 载入器件支持包2. 添加模块3. ST配置4. 外观设置5. 主函数文件 一、课程准备 1. 课程资料 本记录操作流程参考自b站视频BV1th411z7snSTM32入门教程-2023版 细致讲解 中文字幕,课程资…...
![](https://i-blog.csdnimg.cn/direct/2a3a566b24ec47ad89315736e0fa8914.png)
QT实现自定义带有提示信息的透明环形进度条
1. 概述 做界面开发的童鞋可能都会遇到这样的需求,就是有一些界面点击了之后比较耗时的操作,需要界面给出一个环形进度条的进度反馈信息. 如何来实现这样的需求呢,话不多说,上效果 透明进度条 2. 代码实现 waitfeedbackprogressba…...
![](https://www.ngui.cc/images/no-images.jpg)
金币程序题
昨天,小孩问了我一个python编程竞赛题,我看了一下题目,是一个数列编程的问题,我在想,小学五年级的学生能搞得懂吗?反正我家小孩是没有搞懂,不知道别人家的小孩能不能搞明白。所以我花了一点时间…...
![](https://i-blog.csdnimg.cn/direct/0595404e0cad4f66a7cdbf0b95da5346.png)
《Windows API每日一练》9.13资源-鼠标位图和字符串
鼠标指针位图(Mouse Cursor Bitmap)是用于表示鼠标指针外观的图像。在 Windows 窗口编程中,可以使用自定义的鼠标指针位图来改变鼠标的外观,并提供更加个性化的用户体验。 ■以下是一些与鼠标指针位图相关的要点: ●…...
![](https://i-blog.csdnimg.cn/direct/c43783402e424db38c03f78ac9b98978.png)
【保姆级教程】CenterNet的目标检测、3D检测、关键点检测使用教程
一、代码下载 仓库地址:https://github.com/xingyizhou/CenterNet?tab=readme-ov-file 二、目标检测 2.1 下载预训练权重 下载预训练权重ctdet_coco_dla_2x.pth放到models文件夹下 下载链接:https://drive.google.com/file/d/18Q3fzzAsha_3Qid6mn4jcIFPeOGUaj1d/edit …...
![](https://www.ngui.cc/images/no-images.jpg)
thinkphp:数据库复合查询-OR的使用
完整代码 $data[info] db::table(po_headers_all)->alias(ph) //设置wip_jobs_all的别名->join([vendors > ve], ph.vendor_codeve.vendor_code)->field(ph.po_num,ph.status,ph.vendor_code,ve.vendor_name,ph.po_all_amount,ph.note,ph.order_date,ph.need_dat…...
![](https://www.ngui.cc/images/no-images.jpg)
网络安全那些梗
网络安全领域的梗往往以幽默、讽刺或夸张的方式反映了该领域的某些现象、挑战或误解。以下是一些网络安全相关的梗: 关掉服务器是最有效的安全方法:这个梗源自一个笑话,讲述了一位程序员因误解妻子的话而只买了一个包子回家,随后被…...
![](https://img-blog.csdnimg.cn/img_convert/8eee276818d2b6d424044bb2f69e8ce3.jpeg)
交通气象站:保障道路安全的智慧之眼
随着社会的快速发展,交通运输日益繁忙,道路安全成为公众关注的焦点。在这个背景下,交通气象站作为保障道路安全的重要设施,正发挥着越来越重要的作用。它们不仅为交通管理部门提供及时、准确的气象信息,也为广大驾驶员…...
![](https://i-blog.csdnimg.cn/direct/169a8a151b4a4ab4a1b5d67ec1cd3244.webp)
【分库】分库的核心原则
目录 分库的核心原则 前言 分区透明性与一致性保证 弹性伸缩性与容错性设计 数据安全与访问控制机制 分库的核心原则 前言 在设计和实施分库策略时,遵循一系列核心原则是至关重要的,以确保系统不仅能够在当前规模下高效运行,还能够随着…...
![](https://i-blog.csdnimg.cn/direct/c6c42278c28c45d6b7d82eb263d9fb20.png)
【Linux】软件管理工具 yum
文章目录 概念搜索:yum list安装:yum install卸载:yum remove 概念 在Linux下安装软件,可以下载到程序的源代码,进行编译得到可执行程序,另外这些软件还有依赖其它工具的问题,还得下载编译这些依…...
![](https://www.ngui.cc/images/no-images.jpg)
LangChain —— Prompt Templates
文章目录 一、什么是 Prompt Templates1、String PromptTemplates2、ChatPromptTemplates3、MessagesPlaceholder 留言占位符 二、如何使用 Prompt Templates1、使用几个简短示例2、在 chat model 中使用几个简短示例3、部分格式化提示模板4、一起编写提示 一、什么是 Prompt T…...
![](https://www.ngui.cc/images/no-images.jpg)
Python库 - Scrapy
Scrapy 是一个用于爬取网站数据、提取结构性数据的开源和协作框架。它最初是为网页抓取设计的,但也可以用于获取 API 提供的数据或作为通用的网络爬虫。 文章目录 主要特性主要组件使用流程1. 安装 Scrapy2. 创建 Scrapy 项目3. 定义 Item(数据ÿ…...
![](https://i-blog.csdnimg.cn/direct/df0897273b6348189c8237e7ebc64c8c.png)
函数(实参以及形参)
实际参数(实参) 实际参数就是在调用函数时传递给函数的具体值。这些值可以是常量、变量、表达式或更复杂的数据结构。实参的值在函数被调用时传递给对应的形参,然后函数内部就可以使用这些值来执行相应的操作。 int main() {int a 0;int b …...
![](https://www.ngui.cc/images/no-images.jpg)
ArcGIS Pro SDK (八)地理数据库 8 拓扑
ArcGIS Pro SDK (八)地理数据库 8 拓扑 文章目录 ArcGIS Pro SDK (八)地理数据库 8 拓扑1 开放拓扑和进程定义2 获取拓扑规则3 验证拓扑4 获取拓扑错误5 标记和不标记为错误6 探索拓扑图7 找到最近的元素 环境:Visual …...
![](https://www.ngui.cc/images/no-images.jpg)
uniapp如何发送websocket请求
方法1: onLoad() {uni.connectSocket({url: ws://127.0.0.1:8000/ws/stat/realTimeStat/,success: (res) > {console.log(connect success, res);}});uni.onSocketOpen(function (res) {console.log(WebSocket连接已打开!);uni.sendSocketMessage({d…...
![](https://www.ngui.cc/images/no-images.jpg)
RabbitMQ的工作模式
RabbitMQ的工作模式 Hello World 模式 #mermaid-svg-sbc2QNYZFRQYbEib {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-sbc2QNYZFRQYbEib .error-icon{fill:#552222;}#mermaid-svg-sbc2QNYZFRQYbEib .error-text{fi…...
![](https://i-blog.csdnimg.cn/direct/75de551435da4224ac49d186b5e85201.png)
自建搜索引擎-基于美丽云
Meilisearch 是一个搜索引擎,主程序完全开源,除了使用官方提供的美丽云服务(收费)进行对接之外,还可以通过自建搜索引擎来实现完全独立的搜索服务。 由于成本问题,本博客采用自建的方式,本文就…...
![](https://i-blog.csdnimg.cn/direct/168ecd036bed46959673a6e5324343dc.jpeg)
2024辽宁省大学数学建模竞赛试题思路
A题 (1) 建立模型分析低空顺风风切变对起飞和降落的影响 模型假设 飞机被视为质点,忽略其尺寸和形状对风阻的影响。风切变仅考虑顺风方向的变化,忽略其他方向的风切变。飞机的飞行速度、高度和姿态(如迎角、俯仰角)是变化的&am…...
![](https://img-blog.csdnimg.cn/img_convert/f3749a6c0c9bd5fa12a8de4054056877.gif)
循环结构(一)——for语句【互三互三】
文章目录 🍁 引言 🍁 一、语句格式 🍁 二、语句执行过程 🍁 三、语句格式举例 🍁四、例题 👉【例1】 🚀示例代码: 👉【例2】 【方法1】 🚀示例代码: 【方法2】…...
![](https://i-blog.csdnimg.cn/direct/1acdf298a1a94485bdd6c098a5517234.png)
【深度学习基础】MacOS PyCharm连接远程服务器
目录 一、需求描述二、建立与服务器的远程连接1. 新版Pycharm的界面有什么不同?2. 创建远程连接3. 建立本地项目与远程服务器项目之间的路径映射4.设置保存自动上传文件 三、设置解释器总结 写在前面,本人用的是Macbook Pro, M3 MAX处理器&am…...
![](https://i-blog.csdnimg.cn/direct/8aad0542f4484e8aa086fa9f96d03bd9.png#pic_center)
微调Qwen2大语言模型加入领域知识
目录 试用Qwen2做推理安装LLaMA-Factory使用自有数据集微调Qwen2验证微调效果 试用Qwen2做推理 参考:https://qwen.readthedocs.io/en/latest/getting_started/quickstart.html from transformers import AutoModelForCausalLM, AutoTokenizer device "cuda…...
![](https://i-blog.csdnimg.cn/direct/dfbf291b56c44d7d80ec01f473b859f8.png)
【Linux】内核文件系统系统调用流程摸索
内核层可以看到当前调用文件处理的进程ID 这个数据结构是非常大的: 我们打印的pid,tgid就是从这里来的,然后只需要找到pid_t的数据类型就好了。 下图这是运行的日志信息: 从上述日志,其实我也把write的系统调用加了入口的打印信…...
![](https://i-blog.csdnimg.cn/direct/a25da91d61ab403caa5ed1e97b7c2ede.png)
【HZHY-AI300G智能盒试用连载体验】文档资料
感谢电子发烧友和北京合众恒跃科技有限公司提供的的产品试用机会。 HZHY-AI300G工业级国产化智盒,采用RK3588工业级芯片组适应-40℃-85℃工业级宽温网关。 以前测试过其他厂家的RK3568产品,对瑞芯微的工具也比较了解。 在合众恒跃的网站上可以看到基本…...
![](https://i-blog.csdnimg.cn/direct/640f47a1c38c4840a74703ce0a6af9ee.png)
Linux--深入理与解linux文件系统与日志文件分析
目录 一、文件与存储系统的 inode 与 block 1.1 硬盘存储 1.2 文件存取--block 1.3 文件存取--inode 1.4 文件名与 inode 号 编辑 1.5 查看 inode 号码方法 1.6 Linux 系统文件的三个主要的时间属性 1.7 硬盘分区结构 1.8 访问文件的简单了流程 1.9 inode 占用 1.…...
![](https://www.ngui.cc/images/no-images.jpg)
Postman 中的 API 安全性测试:最佳实践与技巧
在当今快速发展的数字化世界中,API(应用程序编程接口)已成为软件系统之间通信的桥梁。然而,随着API使用的增加,安全风险也随之上升。本文将详细介绍如何在 Postman 中进行 API 的安全性测试,帮助开发者和测…...
![](https://img-blog.csdnimg.cn/img_convert/e9bdbf35caf7b2795544a1cac7355f1e.png)
PTC可复位保险丝 vs 传统型保险丝:全面对比分析
PTC可复位保险丝,又称为自恢复保险丝、自恢复熔断器或PPTC保险丝,是一种电子保护器件。它利用材料的正温度系数效应,即电阻值随温度升高而显著增加的特性,来实现电路保护。 当电路正常工作时,PTC保险丝呈现低阻态&…...
![](https://i-blog.csdnimg.cn/direct/5e0e658d9a3c458885b5e3e096b00cff.png)
深入了解Rokid UXR2.0 SDK内置的Unity AR Glass开发组件
本文将了解到Rokid AR开发组件 一、RKCameraRig组件1.脚本属性说明2.如何使用 二、PointableUI组件1.脚本属性说明2.如何使用 三、PointableUICurve组件1.脚本属性说明2.如何使用 四、RKInput组件1.脚本属性说明2.如何使用 五、RKHand组件1.脚本属性说明2.如何使用3.如何禁用手…...
![](https://i-blog.csdnimg.cn/direct/e1d8e82fbc4e4047996965c40e041061.png)
Lottery 分布式抽奖(个人向记录总结)
1.搭建(DDDRPC)架构 DDD——微服务架构(微服务是对系统拆分的方式) (Domain-Driven Design 领域驱动设计) DDD与MVC同属微服务架构 是由Eric Evans最先提出,目的是对软件所涉及到的领域进行建…...
![](/images/no-images.jpg)
宽城区网站建设/免费seo营销软件
近日使用VMware fushion 8 centos 7.0时,无法使用共享功能,所以必须安装vmtools。但是安装过程中有2个错误需要解决。 1、gcc错误 Searching for GCC... The path "" is not valid path to the gcc binary. 2、内核头文件问题 Searching for …...
![](/images/no-images.jpg)
linux主机 安装wordpress/深圳网络营销策划公司
同步自:http://www.blogjava.net/AndersLin/archive/2006/06/27/55421.html 上次发了一文《软件企业的绩效管理和内部消耗》讨论很多,"置身珠海,学习与奋斗"cnBlogs让我认识其实我说了那么多都只是绩效的保健性&…...
![](/images/no-images.jpg)
如何做自己网站/关键词排名优化顾问
https://blog.csdn.net/weixin_42642341/article/details/84585253 thrift : 是Facebook公布的一款开源跨语言的RPC框架....
![](https://img2018.cnblogs.com/blog/1258817/201903/1258817-20190325093445247-432584102.gif)
wordpress 附件密码保护/电脑软件推广平台
一、动图演示 二、思路分析 1. 相邻两个数两两相比,n[i]跟n[j1]比,如果n[i]>n[j1],则将连个数进行交换, 2. j, 重复以上步骤,第一趟结束后,最大数就会被确定在最后一位,这就是冒泡排序又称…...
![](/Images/OutliningIndicators/ExpandedBlockStart.gif)
html与css结合网站开发书籍/网站推广的6个方法是什么
上一篇文章 "无侵入方面编程-用HttpModuleSoapExtension监视页面执行参数(一)"中,我们实现了监视每个页面的执行情况和调用WebService的简单信息。 这次我们继续深入一下SoapExtension的应用,在不改变Soap的WSDL文档的情况下&#…...
![](https://img-blog.csdnimg.cn/img_convert/2de4cc778f5311e58f00e12fa1d22327.gif)
个人备案的网站做企业内容/宁波seo教学
提到开源数据库,人们首先想到的是MySQL,由于性能高、成本低、可靠性好,已经成为目前流行的开源数据库;但MySQL在企业级数据服务,特别是存储引擎和技术支持方面一直被DBA们诟病;即使被Sun收购后也未见在企业…...