iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL中MVCC与BufferPool缓存机制是什么
  • 356
分享到

MySQL中MVCC与BufferPool缓存机制是什么

2023-06-30 15:06:26 356人浏览 八月长安
摘要

本篇内容主要讲解“MySQL中mvcC与BufferPool缓存机制是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Mysql中MVCC与BufferPool缓存机制是什么”吧!一、MVCC

本篇内容主要讲解“MySQLmvcC与BufferPool缓存机制是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习Mysql中MVCC与BufferPool缓存机制是什么”吧!

    一、MVCC机制

    • MVCC(Multi Version Concurrency Control),mysql(默认)RR隔离级别就是通过该机制来保证的,对一行数据的读与写两个操作默认是不会通过加互斥来保证隔离性的

    • 串行化隔离级别是为了保证较高的隔离性,是通过将所有操作加锁互斥来实现的

    • Mysql在RC隔离级别和RR隔离级别下都实现了MVCC机制

    • RC每次查询都会创建一个reade-view,而RR在创建完read-view之后,在不提交事务之前,每次查询还是第一次创建的read-view

    undo日志版本链与read-view机制

    • undo日志版本链是指一行数据被多个事务一次修改后,当每个事务修改完之后,MySQL会保留修改前的数据undo回滚日志,并且用两个隐藏字段trx_id和roll_pointer把只写undo日志串联起来形成一个历史记录版本链.

    • RR隔离级别,当事务开启,执行任何SQL时会生成当前事务的read-view一致性视图,该视图在事务结束之前都不会变化(如果是RC隔离界别在每次执行查询SQL时都会重新生成最新的read-view),这个视图由执行查询时所有未提交的事务id数组(数组里最小的id为min_id)和已创建的最大事务id(max_id)组成,事务里任何SQL查询结果需要从对应版本链里的最新数据开始逐条跟read-view作比对,从而得到最终的结果

    版本链比对规则

    • 如果row的trx_id落在绿色部分(trx < min_id),表示这个版本是已提交的事务生成的,这个数据是可见的

    • 如果row的trx_id落在红色部分(trx > max_id),表示这个版本是由将来启动的(未开始)事务生成的,是不可见的(若row的trx_id就是当前自己的事务是可见的)

    • 如果 row 的 trx_id 落在黄色部分(min_id <= trx_id <= max_id),那就包括两种情况

      • 若 row 的 trx_id 在视图数组中,表示这个版本是由还没提交的事务生成的不可见(若 row 的 trx_id 就是当前自己的事务是可见的)

      • 若 row 的 trx_id 不在视图数组中,表示这个版本是已经提交了的事务生成的可见

    MySQL中MVCC与BufferPool缓存机制是什么

    二、BufferPool机制

    InnoDB执行的BufferPool缓存机制:

    MySQL中MVCC与BufferPool缓存机制是什么

    InnoDB的SQL执行流程:

    • 当客户端执行一条修改的SQL,需要经过Server层,再调用具体的执行引擎

    • 加载数据页,把需要修改数据所在的数据页,缓存到BufferPool

    • 修改前写undo日志,记录更改前数据,如果事务执行失败,使用undo日志进行数据回滚

    • 更新BufferPool中的数据

    • 准备提交事务写redo日志,保存操作记录。redo日志用来恢复已提交事务的BufferPool

    • 准备提交事务写binlog日志,保存操作记录。binlog日志用来恢复磁盘数据

    • 事务提交完成,此时binlog日志写入成功,并且在redo日志中记录了commit标记。事务提交完成后binlog日志和redo日志数据保持一致

    • 数据持久化,IO线程不定期把BufferPool中的数据随机写入到磁盘,完成持久化

    三、总结

    MVCC实现机制(为什么同一个事务第一次查询出来之后,就算其它事务把新数据修改了,当前事务还是看到之前的数据)

    • 它内部实际有个undo日志版本链,然后在事务第一次查询的时候,它会生成一个read-view一致性视图,然后我们后面所有查询的数据都会根据我们的那个undo日志版本链去跟我们当前的read-view里面按照一定的规则逐行去比对查找对应的数据

    BufferPool机制

    • 数据库的增删改查都是直接操作BufferPool的,当我们执行一条修改的SQL经历过Server层之后会调用具体的执行引擎,然后将相关的数据页加载到BufferPool中,修改前写undo日志,记录修改前的数据为了方便事务失败之后的回滚,然后更新BufferPool,准备提交事务写redo日志保存操作记录,因为如果MySQL宕机了会从redo日志中将数据恢复到BufferPool中,然后会写binlog日志,保存操作记录,因为当我们删除数据库跑路时,binlog是用来恢复磁盘数据的,事务提交完成后,binlog日志写入成功,并且在redo日志记录提交标记,此时redo日志和binlog日志数据一致,而redo日志采用顺序IO写入,这样效率堪比内存操作。对于数据持久化,InnoDB会有个后台线程定时去将缓存刷到磁盘里

    为什么MySQL不能直接更新磁盘上的数据而是设置了这么一套复杂的机制来执行SQL

    • 因为来一个请求直接对磁盘文件进行随机读写,然后更新磁盘文件里的数据性能可能相当差.

    • 因为磁盘随机读写的性能是非常差的,所以直接更新磁盘文件时不能让数据库抗住高并发

    • MySQL这套机制看起来很复杂,但它可以保证每个更新请求都是更新内存BufferPool,然后顺序写日志文件,同时还能保证各种异常情况下的数据一致性

    • 更新内存的性能是极高的,然后顺序写磁盘上的日志文件的性能也是非常高的,要远高于随机读写磁盘文件,正是通过这套机制,才能让我们的MySQL数据库在较高配置的机器上每秒可以抗下几千甚至上完的读写请求

    到此,相信大家对“MySQL中MVCC与BufferPool缓存机制是什么”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

    您可能感兴趣的文档:

    --结束END--

    本文标题: MySQL中MVCC与BufferPool缓存机制是什么

    本文链接: https://www.lsjlt.com/news/330117.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • MySQL中MVCC与BufferPool缓存机制是什么
      本篇内容主要讲解“MySQL中MVCC与BufferPool缓存机制是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL中MVCC与BufferPool缓存机制是什么”吧!一、MVCC...
      99+
      2023-06-30
    • 深入理解MySQL中MVCC与BufferPool缓存机制
      目录一、MVCC机制undo日志版本链与read-view机制版本链比对规则二、BufferPool机制三、总结一、MVCC机制 MVCC(Multi Version Concurr...
      99+
      2024-04-02
    • Mysql中MVCC机制的原理是什么
      这篇文章将为大家详细讲解有关Mysql中MVCC机制的原理是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Mysql的锁和事务隔离级别在理解MVCC机制的原理之前,需要先理解Mysql的...
      99+
      2023-06-14
    • redis缓存机制是什么
      redis 的缓存机制通过将数据副本存储在内存中来加速访问,提高应用程序性能。其核心步骤包括:数据写入时存储在内存中;读取时首先检查内存,存在则直接返回,不存在则从持久化存储加载;设置过...
      99+
      2024-04-08
      redis 数据访问 持久化存储
    • Django缓存机制是什么
      本篇内容介绍了“Django缓存机制是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!缓存的介绍在动态网站中,用户所有的请求,服务器都会去...
      99+
      2023-07-05
    • mysql中bufferpool的作用是什么
      MySQL中的Buffer Pool是一个内存缓存区,用于存储数据库表和索引的数据块。它的作用是将磁盘上的数据存储在内存中,以加快数...
      99+
      2024-04-02
    • 什么是HTTP的缓存机制
      这篇文章给大家介绍什么是HTTP的缓存机制,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。缓冲机制普遍存在,有客户端缓存、服务端缓存、代理服务器缓存等。浏览器缓存是在HTTP中起缓存作用的。HTTP缓存作为优化web性能...
      99+
      2023-06-25
    • MySQL的查询缓存机制是什么意思
      本篇内容主要讲解“MySQL的查询缓存机制是什么意思”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL的查询缓存机制是什么意思”吧!  查询必须是完全相同...
      99+
      2024-04-02
    • shiro中缓存机制的原理是什么
      本篇文章给大家分享的是有关shiro中缓存机制的原理是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Shiro提供了类似于Spring的Cache抽象,即Shiro本身不实...
      99+
      2023-05-31
      shiro
    • hibernate二级缓存机制是什么
      Hibernate二级缓存机制是指在Hibernate框架中,通过配置第二级缓存来缓存对象的持久化状态,提高数据库访问性能。Hibe...
      99+
      2023-08-24
      hibernate
    • android本地缓存机制是什么
      Android本地缓存机制是指将数据临时存储在设备上,以便在需要时可以快速访问,而不需要每次都从远程服务器获取数据。Android提...
      99+
      2023-09-13
      android
    • redis缓存存储Session原理机制是什么
      这篇文章主要讲解了“redis缓存存储Session原理机制是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“redis缓存存储Session原理机制是什么”吧!基于 Redis 存储 S...
      99+
      2023-06-25
    • JavaScript中的缓存机制与GO语言的缓存机制有何区别?
      在现代程序开发中,缓存机制是非常常见的一种优化方法。缓存可以大幅度提高程序的运行效率,减少资源的消耗,提高用户体验。在JavaScript和GO语言中,缓存机制也得到了广泛的应用。本文将从JavaScript和GO语言的角度探讨缓存机制的...
      99+
      2023-11-13
      数据类型 缓存 javascript
    • mysql中MVCC的作用是什么
      本篇文章为大家展示了mysql中MVCC的作用是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1、说明多版并发控制MVCC是MySQL InnoDB存储引擎实现隔离等级的具体方法,用于实现提交阅...
      99+
      2023-06-15
    • ASP.NET缓存机制基础概念是什么
      这篇文章主要讲解了“ASP.NET缓存机制基础概念是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“ASP.NET缓存机制基础概念是什么”吧!ASP.NET缓存机制名词解释页输出缓存:保存...
      99+
      2023-06-18
    • 什么是MySQL缓存池
      本篇内容主要讲解“什么是MySQL缓存池”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“什么是MySQL缓存池”吧!前言面试官:同学,你能说说Mysql 缓存池吗...
      99+
      2024-04-02
    • 缓存服务器的运作机制是什么
      本篇内容介绍了“缓存服务器的运作机制是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!用户在访问服务器的时候服务器需要将用户的请求以及应用...
      99+
      2023-06-27
    • 什么是MySQL查询缓存
      本篇内容主要讲解“什么是MySQL查询缓存”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“什么是MySQL查询缓存”吧!QueryCache介绍MySQL查询缓(...
      99+
      2024-04-02
    • Qt中的双缓冲机制与应用方法是什么
      本篇内容介绍了“Qt中的双缓冲机制与应用方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、双缓冲机制所谓双缓冲机制,是指在绘制控件...
      99+
      2023-07-05
    • PHP中怎么实现缓存机制
      这篇文章给大家介绍PHP中怎么实现缓存机制,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。普遍缓存技术数据缓存:这里所说的数据缓存是指数据库查询PHP缓存机制,每次访问页面的时候,都会先检测相应的缓存数据是否存在,如果不...
      99+
      2023-06-17
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作