热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

MVCC多版本控制事务篇

MVCC多版本控制-事务篇1.MVCC概述1.1MVCC定义MVCC全称MutliVersionConcurrenyControl,多版本并发控制,也可以称为一致性非锁定读,通过行




MVCC多版本控制-事务篇

1.MVCC概述


1.1 MVCC定义

MVCC全称Mutli Version Concurreny Control,多版本并发控制,也可以称为一致性非锁定读,通过行的多版本控制方式来读取当前执行时间 数据库的行数据 .MVCC实际上是用的快照数据,实现快照读.MVCC主要应用于RC,RR两个级别.


1.2 为什么使用MVCC

innoDB和MyISAM相比有两大特点:一是支持事务 ,二是支持行级锁.

针对于innoDB四种隔离级别的串行隔离级来说,并发事务处理能大大增加数据资源的利用率,提高数据库系统的事务吞吐量.但是并发事务也会带来一些问题,主要包括:























问题描述
脏读某个事务正在更新了一份数据,在另一个事务里可以看到前一个事务正在编辑的数据
不可重复读在RC级别会出现不可重复读的问题.在一个事务的两次查询之中数据出现不一致状态.
幻读是针对于数据的插入或删除造成的读不一致

innoDB为解决并发事务问题提供了以下两种方法:




  1. MVCC



  • undo 日志

undo log的作用:保存了事务在发生变动之前的一个版本,可以用于回滚.同时可以提供多版本的并发控制下的读.

undo log的两种功能 :



  1. 事务回滚

  2. MVCC

innodb的物理存储结构:innoDB的数据保存在独立表空间中,数据回滚主要记录在undo日志里,记录文件为ibdata1,ibdata2.用



推荐阅读
  • 协程作为一种并发设计模式,能有效简化Android平台上的异步代码处理。自Kotlin 1.3版本引入协程以来,这一特性基于其他语言的成熟理念,为开发者提供了新的工具,以增强应用的响应性和效率。 ... [详细]
  • CentOS下ProFTPD的安装与配置指南
    本文详细介绍在CentOS操作系统上安装和配置ProFTPD服务的方法,包括基本配置、安全设置及高级功能的启用。 ... [详细]
  • JUC并发编程——线程的基本方法使用
    目录一、线程名称设置和获取二、线程的sleep()三、线程的interrupt四、join()五、yield()六、wait(),notify(),notifyAll( ... [详细]
  • Redis:缓存与内存数据库详解
    本文介绍了数据库的基本分类,重点探讨了关系型与非关系型数据库的区别,并详细解析了Redis作为非关系型数据库的特点、工作模式、优点及持久化机制。 ... [详细]
  • 关于进程的复习:#管道#数据的共享Managerdictlist#进程池#cpu个数1#retmap(func,iterable)#异步自带close和join#所有 ... [详细]
  • 在Android应用开发过程中,开发者经常遇到诸如CPU使用率过高、内存泄漏等问题。本文将介绍几种常用的命令及其应用场景,帮助开发者有效定位并解决问题。 ... [详细]
  • 为何Compose与Swarm之后仍有Kubernetes的诞生?
    探讨在已有Compose和Swarm的情况下,Kubernetes是如何以其独特的设计理念和技术优势脱颖而出,成为容器编排领域的领航者。 ... [详细]
  • 在中标麒麟操作系统上部署达梦数据库及导入SQL文件
    本文档详细介绍了如何在中标麒麟操作系统上安装达梦数据库,并提供了导入SQL文件的具体步骤。首先,检查系统的发行版和内核版本,接着创建必要的用户和用户组,规划数据库安装路径,挂载安装介质,调整系统限制以确保数据库的正常运行,最后通过图形界面完成数据库的安装。 ... [详细]
  • spring boot使用jetty无法启动 ... [详细]
  • 本文详细介绍了如何正确设置Shadowsocks公共代理,包括调整超时设置、检查系统限制、防止滥用及遵守DMCA法规等关键步骤。 ... [详细]
  • flea,frame,db,使用,之 ... [详细]
  • 探讨在 Swoole 的 WorkerStart 回调中创建的对象如何在多个客户端之间实现隔离,确保每个客户端的数据独立性。 ... [详细]
  • 在 Ubuntu 22.04 LTS 上部署 Jira 敏捷项目管理工具
    Jira 敏捷项目管理工具专为软件开发团队设计,旨在以高效、有序的方式管理项目、问题和任务。该工具提供了灵活且可定制的工作流程,能够根据项目需求进行调整。本文将详细介绍如何在 Ubuntu 22.04 LTS 上安装和配置 Jira。 ... [详细]
  • 本文详细介绍了进程、线程和协程的概念及其之间的区别与联系。进程是在内存中运行的独立实体,具有独立的地址空间和资源;线程是操作系统调度的基本单位,属于进程内部;协程则是用户态下的轻量级调度单元,性能更高。 ... [详细]
  • 电商高并发解决方案详解
    本文以京东为例,详细探讨了电商中常见的高并发解决方案,包括多级缓存和Nginx限流技术,旨在帮助读者更好地理解和应用这些技术。 ... [详细]
author-avatar
麦豪小仙
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有