当前位置: 首页 > news >正文

MySQL----MVCC机制

一、概述

首先,我们要先搞懂MVCC是用来做什么的,它本身是一个并发控制思想,用于在并发情况先,读操作不阻塞写操作,写操作不阻塞读操作,从而大幅度提高MySQL数据库的并发能力。(还有一种说法是解决不可重复读的问题)在MySQL中,MVCC是由版本链和readView组成的。首先,版本链是由Undolog日志和MySQL针对每行数据的隐藏字段--trx_id和上个版本的指针。而readView它定义了当前事务能看到哪些版本的数据,可以看作是当前数据库的一个“快照”。

二、readView解析

它是由以下字段组成,它们的大概意思是:

1.min_id:最小事务Id(活跃事务的最小Id)

2.max_id:全局的下一个事务Id。

3.cur_trx_id:当前的事务Id。

4.active_id_list:当前活跃的事务Id。

首先,小于min_id的事务都是已经提交的,一定是可以读的,其次active_id_list中的Id都是正在写的,也就是还没提交的,是一定不能读的。如果事务Id是大于等于max_id的,那也是不可以读的。如果id小于max_id同时大于min_id,还不在active_id_list中的。它是已经提交的事务,也是可以读的。

同时readView的生成时机也决定了MySQL的隔离级别,如果每次进行查询时都更新一次,那它就是读已提交的级别,因为此时MySQL并不能保证两次读的数据是一样的。如果只在第一次查询时更新,那么它就是可重复读的隔离级别。因为此时可读的事务Id都是固定的,每次查询结果都一样。

三、版本链

首先InnoDB数据引擎会在每张表中生成以下隐藏字段:

1.DB_TRX_ID:表示最后一次插入或修改该数据的事务Id,同时Del操作也被视为一次特殊更新。

2.DB_ROLL_PTR:它指向上一个历史版本在UndoLog中的地址,它将这些历史版本串为一个版本链。

3.DB_ROW_ID:这个在表中没有主键时自动生成,与MVCC关系不大。

而UndoLog则是一个日志,它会将每次对数据的更新操作都记录进来,包含每个字段的值。DB_ROLL_PTR则将这些记录都连起来,形成一个版本链,链头是最新的版本,链尾则是最旧的版本。

四、MVCC的优缺点

优点:读操作大部分无需加锁,显著提高了MySQL的并发能力,而且也为实现可重复读提供了一个参考思路。

缺点:需要维护Undolog,这无法避免的增加了空间开销,同时还要引入Purge线程来单独定期清除UndoLog,不然会无限增长。同时引入一个新机制,MySQL的系统复杂度也会上升。

http://www.dtcms.com/a/391274.html

相关文章:

  • 设计|str增量法|计算贡献
  • Spring中Controller层中容易搞混的注解
  • Git GitHub 个人账户创建教程
  • Python学习系统计划:从零到精通的科学路径
  • 解锁 JavaScript 的数学魔法:深入探索 Math 对象
  • dcm4che系列主要开源项目概述
  • 枚举深入解析
  • Qt中delete与deleteLater()的使用
  • AD5621(单通道缓冲电压输出DAC)芯片的详细用法
  • vLLM的面试题
  • 最优控制3 -- 动态规划-一个解析解的例子
  • 深入分析大众点评 Ajax 接口:直接请求 JSON 数据高效获取评论
  • 京东零售张科:DataAI Infra会成为驱动未来的技术基石
  • Java 运维中的一些常用命令
  • 用 go-commons 打造一套最小可行监控体系
  • 广东省省考备考(第一百零二天9.19)——言语(拔高突破第二节课)
  • 在vscode中,在powershell 下,如何进入子目录?
  • 易语言源码怎么制作软件 易语言源码和模块怎么做成软件
  • 4-2〔O҉S҉C҉P҉ ◈ 研记〕❘ WEB应用攻击▸目录遍历漏洞-B
  • 【Javaweb】http协议-请求与响应
  • 内网穿透系列十三:wstunnel 一款通过 Websocket 或 HTTP2 隧道传输的内网穿透工具
  • 【开关电源篇】自激振荡开关电源原理详解-从模块解析到故障维修
  • SpringBoot+Vue实现图片上传
  • C++ 函数指针与排序策略
  • 12分钟讲解Python核心理念
  • 01数据结构-串和KMP算法
  • 前端性能优化实用方案(三):骨架屏提升30%用户感知速度
  • NVR设备ONVIF接入平台EasyCVR视频融合平台智慧小区视频监控一站式建设方案
  • window XP环境下配置VC6.0的Win32汇编语言开发环境
  • 【算法】0_算法工程师常见算法题