【MySQL】mvcc以及三个重要日志

🍎个人博客:个人主页

🏆个人专栏:【】数据库

⛳️  功不唐捐,玉汝于成


目录

前言

正文

MVCC关键概念:

MVCC机制的优点:

三个重要的日志:

重做日志:

回滚日志:

事务日志:

结语

 我的其他博客


 

前言

在数据库管理系统中,实现并发控制是至关重要的,特别是在高并发环境下。传统的锁机制在处理并发操作时可能会导致性能瓶颈,因此引入了MVCC(Multi-Version Concurrency Control)机制,为数据库系统带来了新的解决方案。MVCC通过维护多个数据版本和事务视图,实现了读操作与写操作之间的并发性,提高了数据库的性能和并发能力。本文将深入探讨MVCC的原理、实现和优点,帮助读者更好地理解这一关键技术。

正文

MVCC(Multi-Version Concurrency Control)是一种数据库并发控制机制,主要用于管理数据库系统中多个事务同时读写相同数据时的并发操作。MVCC的核心思想是为每个事务创建一个可见的数据版本,从而允许读取操作与写入操作同时进行而不会相互阻塞。这样可以提高数据库系统的并发性能和效率。

MVCC关键概念:

  1. 数据版本: 在MVCC中,对于每个数据行,数据库系统会维护多个版本。每个事务开始时,系统会将当前数据行的一个快照复制给该事务,以便事务在其执行期间读取数据时看到一致的状态。如果其他事务正在对该数据行进行修改,事务也会看到之前的版本,从而保证了读取操作的一致性和隔离性。

  2. 版本号: 每个数据版本都会有一个唯一的版本号或者时间戳,用于标识该版本的创建时间或者序列顺序。通过比较事务的启动时间或者版本号,数据库系统可以确定哪个版本的数据对当前事务是可见的。

  3. Read-View(读视图): 在执行读取操作时,每个事务会创建一个读视图,用于确定可见的数据版本。读视图包含了事务开始时数据库中所有活跃事务的快照,以及事务自身开始之前已经提交的事务的版本信息。通过读视图,事务可以确定自己能够看到哪些数据版本,从而实现读操作的隔离性。

  4. Write-View(写视图): 在执行写入操作时,事务会创建一个写视图,用于跟踪事务对数据的修改。写视图包含了事务执行期间对数据的更新操作,但并不影响其他事务的读取操作。只有在事务提交时,写视图的修改才会应用到数据库中,从而保证了写操作的原子性和持久性。

MVCC机制的优点:

  • 读操作与写操作之间不会相互阻塞,提高了数据库的并发性能。
  • 提供了事务级别的隔离性,保证了数据的一致性。
  • 可以实现快照读取,避免了读取操作的锁等待。

总的来说,MVCC是一种高效的并发控制机制,通过维护多个数据版本和事务视图来实现对数据的并发访问和修改,从而提高了数据库系统的性能和可靠性。

MVCC主要通过使用多个数据版本来实现,并结合三个重要的日志来确保事务的原子性、一致性和持久性。

三个重要的日志:

  1. 重做日志

    • 作用:记录数据页发生变化的情况,以便在数据库崩溃恢复时重新执行已经提交的事务。
    • 区别:在事务提交之前,重做日志将事务的变更写入日志,而不是立即将其写入磁盘上的数据文件。这样可以避免频繁地更新磁盘数据,提高性能。
  2. 回滚日志

    • 作用:记录事务对数据的修改,在事务回滚或者发生回滚操作时使用。
    • 区别:回滚日志记录了事务执行前的数据状态,以便在事务回滚时撤销已经执行的操作,使得数据库恢复到事务开始之前的状态。
  3. 事务日志

    • 作用:记录了事务的开始和结束信息,用于事务的原子性和持久性。
    • 区别:事务日志用于记录事务的提交或回滚操作,以便在数据库崩溃后,通过重做日志和回滚日志来恢复已提交的事务或者回滚未提交的事务。

这些日志共同作用,确保了数据库事务的 ACID 特性:

  • 原子性(Atomicity):事务要么全部执行,要么全部回滚。
  • 一致性(Consistency):事务执行前后数据库从一个一致状态转换到另一个一致状态。
  • 隔离性(Isolation):事务之间相互隔离,互不干扰。
  • 持久性(Durability):事务一旦提交,其结果就是永久性的。

MVCC机制借助这些日志来实现事务的隔离和持久性。当一个事务正在对某个数据执行修改操作时,其他事务可以读取该数据的旧版本,这样就实现了读写操作的并发性。MVCC同时通过回滚日志和重做日志来确保事务的原子性和持久性,即使在数据库崩溃或断电情况下也能够保证数据的一致性和完整性。

结语

MVCC作为一种高效的并发控制机制,已经被广泛应用于现代数据库系统中。通过创建多个数据版本和事务视图,MVCC实现了读写操作的并发执行,提高了数据库系统的性能和可靠性。深入理解MVCC的原理和实现对于数据库开发人员和系统管理员来说是至关重要的。希望本文能够帮助读者更好地理解MVCC,并在实践中发挥其优势,从而提升数据库系统的效率和性能。

 我的其他博客

【MySQL】数据库规范化的三大法则 — 一探范式设计原则-CSDN博客

【JAVA】线程的run()和start()有什么区别?-CSDN博客

【日常聊聊】程序员必备的面试技巧:如何在面试战场上脱颖而出-CSDN博客

【JAVA】Java8开始ConcurrentHashMap,为什么舍弃分段锁-CSDN博客

【JAVA】怎么确保一个集合不能被修改-CSDN博客

【Web开发】会话管理与无 Cookie 环境下的实现策略-CSDN博客

【Mybatis】Mybatis如何防止sql注入-CSDN博客

【软件工程】航行敏捷之路:深度解析Scrum框架的精髓-CSDN博客

【Spring】理解IoC与AOP:构建灵活而模块化的软件架构-CSDN博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/422261.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

centos7单节点部署ceph(mon/mgr/osd/mgr/rgw)

使用ceph建议采用多节点多磁盘方式部署,本文章仅作为单节点部署参考,请勿用于生产环境 使用ceph建议采用多节点多磁盘方式部署,本文章仅作为单节点部署参考,请勿用于生产环境 使用ceph建议采用多节点多磁盘方式部署,…

最佳实践:Websocket 长连接状态如何保持

WebSocket 是一种支持通过单个 TCP 连接进行全双工通信的协议,相较于传统的 HTTP 协议,它更适合需要实时交互的应用场景。此协议在现代 Web 应用中扮演着至关重要的角色,尤其是在需要实时更新和通信的场合下维持持久连接。本文将探讨 WebSock…

前端Vue.js中自定义登录界面切换Tabs组件的开发与应用

前端Vue.js中自定义登录界面切换Tabs组件的开发与应用 摘要: 随着Web应用的不断发展,登录界面的设计变得越来越重要。在登录界面中,切换不同的登录方式(如账号登录、验证码登录等)是一种常见的需求。本文将介绍一款基…

前端【技术类】资源学习网站整理(那些年的小网站)

学习网站整理 值得分享的视频博主:学习网站链接 百度首页的资源收藏里的截图(排列顺序没有任何意义,随性而已~),可根据我标注的关键词百度搜索到这些网站呀,本篇末尾会一一列出来,供大家学习呀 …

Laravel框架: Call to a member function connect() on null 异常报错处理

Laravel框架: Call to a member function connect() on null 异常报错处理 Date: 2024.03.01 21:03:11 author: lijianzhan 原文链接: https://learnku.com/laravel/t/63721 问题: local.ERROR: Call to a member function connect() on null {"…

【洛谷 P9240】[蓝桥杯 2023 省 B] 冶炼金属 题解(二分答案)

[蓝桥杯 2023 省 B] 冶炼金属 题目描述 小蓝有一个神奇的炉子用于将普通金属 O 冶炼成为一种特殊金属 X。这个炉子有一个称作转换率的属性 V V V, V V V 是一个正整数,这意味着消耗 V V V 个普通金属 O 恰好可以冶炼出一个特殊金属 X,当普…

redis03 八种数据类型

思维草图 String类型 字符串类型,是redis中最简单的存储类型,可以包含任何数据,例如jpg图片或者序列化的对象等,底层都是以字节数组形式存储,最大能存储512MB的数据。 常用命令 KEY命名规范 加前缀,分…

适配器模式 详解 设计模式

适配器模式 适配器模式是一种结构型设计模式,其主要作用是解决两个不兼容接口之间的兼容性问题。适配器模式通过引入一个适配器来将一个类的接口转换成客户端所期望的另一个接口,从而让原本由于接口不匹配而无法协同工作的类能够协同工作。 结构 适配…

Revit-二开之创建FilledRegion-(2)

Revit-二开之创建FilledRegion FilledRegion在Revit注释模块中,具体位置如图所示 图中是Revit2018版本 Revit绘制FilledRegion 在此文中我们通过创建矩形填充区域为例 继上图操作后在修改面板中选择【绘制】中的矩形,如下图所示 在空白的平面视图中拖…

2024年领取腾讯云优惠券的方法有哪些?程序员爆肝整理

腾讯云代金券领取渠道有哪些?腾讯云官网可以领取、官方媒体账号可以领取代金券、完成任务可以领取代金券,大家也可以在腾讯云百科蹲守代金券,因为腾讯云代金券领取渠道比较分散,腾讯云百科txybk.com专注汇总优惠代金券领取页面&am…

springboot基于web的网上摄影工作室的开发与实现论文

网上摄影工作室 摘要 随着信息技术在管理上越来越深入而广泛的应用,管理信息系统的实施在技术上已逐步成熟。本文介绍了网上摄影工作室的开发全过程。通过分析网上摄影工作室管理的不足,创建了一个计算机管理网上摄影工作室的方案。文章介绍了网上摄影工…

2024最新算法:河马优化算法(Hippopotamus optimization algorithm,HO)求解23个基准函数,提供MATLAB代码

一、河马优化算法 河马优化算法(Hippopotamus optimization algorithm,HO)由Amiri等人于2024年提出,该算法模拟了河马在河流或池塘中的位置更新、针对捕食者的防御策略以及规避方法。河马优化算法的灵感来自河马生活中观察到的三…

chatgpt-3的文章生成器有哪些?可以批量生成文章的生成器

GPT-3(Generative Pre-trained Transformer 3)作为人工智能领域的一项重大突破,开启了新一代的文本生成技术。同时市面上也涌现出了一些GPT-3文章生成器,为用户提供了快速、高效地生成各种类型文章的工具。本文将介绍一些中国的GP…

nest.js使用nest-winston日志一

nest-winston文档 nest-winston - npm 参考:nestjs中winston日志模块使用 - 浮的blog - SegmentFault 思否 安装 cnpm install --save nest-winston winstoncnpm install winston-daily-rotate-file 在main.ts中 import { NestFactory } from nestjs/core; im…

HarmonyOS—编译构建概述

编译构建是将应用/服务的源代码、资源、第三方库等,通过编译工具转换为可直接在硬件设备上运行的二进制机器码,然后再将二进制机器码封装为HAP/APP软件包,并为HAP/APP包进行签名的过程。其中,HAP是可以直接运行在模拟器或真机设备…

【数据结构】实现队列

大家好,我是苏貝,本篇博客带大家了解队列,如果你觉得我写的还不错的话,可以给我一个赞👍吗,感谢❤️ 目录 一. 队列的概念及结构二. 队列的实现队列的结构体初始化销毁队尾插入队头删除显示第一个节点的值…

C++菱形继承_多态

💓博主CSDN主页:麻辣韭菜-CSDN博客💓   ⏩专栏分类:http://t.csdnimg.cn/362T6⏪   🚚代码仓库:要相信光/C高阶🚚   🌹关注我🫵带你学习更多C知识   🔝🔝 目录 前言…

【Excel PDF 系列】EasyExcel + iText 库实现 Excel 转换 PDF

你知道的越多,你不知道的越多 点赞再看,养成习惯 如果您有疑问或者见解,欢迎指教: 企鹅:869192208 文章目录 前言转换前后效果引入 pom 配置代码实现定义 ExcelDataVo 对象主方法EasyExcel 监听器 前言 最近遇到生成 …

2024第二次培训:win11系统下使用nginx、JDK、mysql搭建基于vue2、java前后端分离的web应用运行环境

一.背景 公司安排了带徒弟的任务,给培训写点材料。前面分开介绍了mysql、jdk、nginx的安装,都只是零星的介绍,只能算零散的学习。学习了有什么用呢?能解决什么问题?能完成什么工作? 今天我们要用之前的几篇…

TCP/UDP,HTTP、HTTPS存在什么风险会影响到网络安全吗

近年来,随着网络技术的飞速发展,互联网影响人们的方方面面,我们平时也接触到许多以前从未听过的东西,今天德迅云安全就来分享下一些互联网安全知识,讲解一些关于常看到的关于IP, TCP/UDP,HTTP、HTTPS这些名…