【必会面试题】快照读、当前读是什么?如何理解

目录

    • 1. 当前读(Current Read)
    • 2.快照读(Snapshot Read)
    • 3.总结流程图

快照读和当前读是MySQL数据库的重要机制,也是高频的面试题。首先我们要知道以下几个概念。

  • 缓存机制:缓存是系统中用于存储经常访问的数据的内存空间,以减少对磁盘I/O的需求,提高数据读取的性能。
  • 当前读:当前读直接读取最新数据,并可能需要加锁来确保数据一致性。
  • 快照读:快照读基于事务开始时的一致性视图,不受其他事务影响,依赖MVCC机制。
  • MVCC:MVCC通过维护数据的多个版本来实现并发控制,为快照读提供支持。
  • 锁机制:锁机制用于确保数据一致性,避免并发事务导致的数据冲突。

1. 当前读(Current Read)

概念
当前读是指读取操作直接访问最新的数据,数据读取过程中会受到其他并发事务的影响。这意味着,如果在当前读过程中有其他事务修改了数据,那么当前读会读取到最新的修改。

原理
当前读依赖于数据存储系统的读写锁机制来保证数据一致性。在数据库系统中,当前读通常涉及锁机制,例如共享锁(S锁)和排他锁(X锁),以确保读取过程中的数据一致性。

应用场景
举个例子,在开发一个日志处理系统时,需要高效地读取大量日志文件。理解当前读的原理可以帮助我们优化读取性能,例如:

  • 使用缓冲读取(Buffered Read)来减少系统调用次数。
  • 利用内存映射文件(Memory Mapped File)来加速大文件的读取。
  • 实现异步 I/O 操作,提高并发读取的性能。
缓存命中
缓存未命中
程序调用read
操作系统检查缓冲区
返回数据
从磁盘读取数据
更新缓冲区

2.快照读(Snapshot Read)

快照读的主要挑战在于如何在缓存中维护多个数据版本,以及如何在读取操作时选择合适的版本。

实现原理
为了处理缓存机制,系统需要确保缓存中的数据与磁盘上的数据版本一致。以下是具体的实现策略:

  • 版本列表:每个数据项在缓存中有多个版本,每个版本对应一个快照。
  • 版本元数据:每个版本包含数据的具体值以及版本的时间戳或事务ID。
缓存
数据项1
数据项2
版本1
版本2
版本1
版本2

读取操作
当进行快照读时,系统会根据当前事务的快照时间戳或事务ID,从缓存中选择合适的版本进行读取。

  • 选择合适版本:读取操作时,根据事务的快照时间戳,从版本列表中选择最接近且不超过快照时间戳的版本。
  • 数据一致性:如果缓存中没有合适的版本,系统会从磁盘读取数据并将其版本添加到缓存中。

写入操作
写入操作需要更新缓存中的数据版本,同时确保不影响其他事务的快照读。

  • 更新最新版本:写入操作时,更新缓存中最新的数据版本,并为新版本分配新的时间戳或事务ID。
  • 保留旧版本:旧版本仍然保留在缓存中,以便进行快照读时使用。

应用场景

示例:

假设有一个高并发的订单系统,需要频繁读取和更新订单信息。通过使用快照读和缓存机制,可以确保在读取操作时获取一致性视图,同时提高系统的读取性能。

-- 创建表
CREATE TABLE orders (order_id INT PRIMARY KEY,order_status VARCHAR(20),update_time TIMESTAMP
);-- 读取操作
START TRANSACTION;
-- 使用缓存读取,基于快照时间戳选择版本
SELECT order_status FROM orders WHERE order_id = 1;-- 写入操作
START TRANSACTION;
-- 更新缓存中的最新版本,同时保留旧版本
UPDATE orders SET order_status = 'shipped', update_time = NOW() WHERE order_id = 1;
COMMIT;

3.总结流程图

MVCC机制
锁机制
缓存机制
当前读
快照读
基于快照读取
根据MVCC选择版本
从磁盘读取快照数据
加锁读取
数据是否已加锁?
加锁
从磁盘读取最新数据
等待或失败
处理锁冲突
从缓存读取数据
更新缓存
缓存中存储多个版本
读取请求
缓存命中?
选择读模式
返回最新数据
返回快照数据

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

中英双语介绍美国的州:北达科他州(North Dakota)

中文版 北达科他州简介 北达科他州(North Dakota)位于美国中西部的北部,以其广袤的草原、丰富的农业资源和石油产业而闻名。以下是对北达科他州的详细介绍,包括其地理位置、人口、经济、教育、文化和主要城市。 地理位置 北达…

ID3算法决策树

步骤: 先计算出信息量;信息熵;信息增量; 再比较信息增量的大小,确定分类依据。 信息量: 信息熵: 信息增益:

Android View滑动冲突解决方案

文章目录 前言1. 滑动冲突2. 解决方案2.1 外部解决法2.2 内部拦截法 参考资料 前言 本文需要读者对View事件分发的流程有基本的了解,如果还未完全理解事件分发流程的,需要先学习相关部分内容,这部分可以参考我的上一个博客: And…

Postman使用教程

传统接口风格 RESTful风格 使用Postman完成测试用例目标: Postman教程 (1)准备工作,下载Postman新建 (2)登录接口调试-获取验证码 (3)登录接口调试-登录 (4)…

线程的联合

当前线程邀请调用方法的线程优先执行,在调用方法的线程执行结束之前,当前线程不能再次执行。线程A在运行期间,可以调用线程B的join()方法,让线程B和线程A联合。这样,线程A就必须等待线程B执行完毕后,才能继…

Mysql查询IFNULL和想象的不一样

select sum(ifnull(a,0)) aaa,ifnull(sum(a),0) bbb from (select g.goodsid a from goods g where g.goodsid 601 ) tmp #注意 goodsid 601 的不存在 ​​​ 返回的结果和想象中不同,解释如下 在您SQL查询中,创建了一个子查询(别名为tmp&a…

【深度解析】滑动窗口:目标检测算法的基石

标题:【深度解析】滑动窗口:目标检测算法的基石 目标检测是计算机视觉领域的一个核心任务,旨在识别图像中所有感兴趣的目标,并确定它们的位置和大小。滑动窗口方法作为目标检测中的一种传统技术,虽然在深度学习时代逐…

Linux 操作系统详解

前言 Linux 是一个强大且开源的操作系统,以其稳定性、灵活性和安全性广受欢迎。它在个人计算机、服务器、嵌入式系统以及超级计算机等多个领域得到广泛应用。本文将从多个角度深入探讨 Linux 的历史、架构和主要特性,为初学者和专业人士提供全面的理解和…

Linux_管道通信

目录 一、匿名管道 1、介绍进程间通信 2、理解管道 3、管道通信 4、用户角度看匿名管道 5、内核角度看匿名管道 6、代码实现匿名管道 6.1 创建子进程 6.2 实现通信 7、匿名管道阻塞情况 8、匿名管道的读写原子性 二、命名管道 1、命名管道 1.1 命名管道通信 …

国内外大模型集合

为了满足日益增长的AI需求,我们精心打造了一站式大模型导航网站,旨在成为连接您与全球顶尖人工智能模型的桥梁。无论您是科研工作者、开发者还是对AI充满好奇的探索者,这里都有您所需。 国内大模型精选 通义千问 —— 阿里巴巴集团倾力打造…

某业帮六月校招后端笔试

题目一 解题思路 签到题,dp就行。 题目二 解题思路 这个比较烦人,需要处理额外的引号和括号。用DFS,对于每个间隙,插入与不插入都搜一遍。 题目三 解题思路: 双指针,左右各一个指针,对比长度&…

OpenLCA、GREET、R语言的生命周期评价方法、模型构建

原文链接:OpenLCA、GREET、R语言的生命周期评价方法、模型构建教程https://mp.weixin.qq.com/s?__bizMzUzNTczMDMxMg&mid2247608240&idx6&sn1b5758206d500399fe7cc69e800f61fe&chksmfa826657cdf5ef413d31557941a1c5db5cc84bba8d0f408c469e05a4118c…

#LinuxC高级 笔记一

linux命令 什么是嵌入式? 以应用为中心,以计算机技术为基础,软件硬件可裁剪,适用于对功能、可靠性、成本、体积、功耗有严格要求的专用计算机系统 计算机系统组成? 硬件、软件 操作系统? ios windows harmo…

k8s_集群搭建_k8s管理前端_dashboard安装部署---分布式云原生部署架构搭建017

然后再去安装一下一个dashboard,有了这个以后,操作k8s集群就不用 一直敲命令了 可以看到上面的命令拿过来,然后 执行就可以了 然后如果执行慢,可以直接先去下载,使用wget,然后再去 也可以在浏览器访问,把内容拿到,然后 下面是内容: # Copyright 2017 The Kubernetes Author…

登 Cell 子刊!清华大学张强锋课题组开发 SPACE 算法,组织模块发现能力领先同类工具

多细胞生物中的细胞尽管共享相同的基因组,但因其内部基因调控网络的差异以及与周围微环境中相邻细胞的外部信号交流,使得它们在形态、基因表达和功能上展现出显著的多样性。为了将细胞类型信息与其在组织内的空间位置相关联,空间转录组学 (Sp…

Vue86-Vuex中的getters属性

一、getters的使用 1-1、index.js中getters的书写 计算属性computed靠return获得返回值! 1-2、组件中getters的调用 state是数据源,getters是拿着数据源里的东西进行一番加工。像极了:data和computed 二、小结

vue 启动项目报错Syntax Error: Error: PostCSS received undefined instead of CSS string

启动vue项目然后报错如下图 这个是跟node版本有关系 因为要开发不同的项目使用不同的node版本,所以就用nvm切换,所以导致了node-sass编译问题 执行这个命令就可以 npm install node-sass or npm rebuild node-sass node-sass对于node高版本和低版本切…

智能胎教仪,科技与教育的融合-N9301胎教仪语音方案

随着科学技术的不断进步,人们对婴幼儿教育的认知也日趋成熟和全面。其中,胎教作为一种重要的早期教育方式,近年来备受瞩目。而胎教仪语音芯片的研发,正是为了满足这一需求,为胎儿的健康成长提供更加便捷的胎教方案。 一…

Tomcat服务部署安装

一、Tomcat基础 1.Tomcat简介 Tomcat服务器是一个免费的开放源代码的Web应用服务器,Tomcat虽然和Apache或者Nginx这些Web服务器一样,具有处理HTML页面的功能,然而由于其处理静态HTML的能力远不及Apache或者Nginx,所以Tomcat通常…

Linux 程序置顶脚本

引言 当希望我们运行的程序,一直保持在最顶端运行,即置顶状态,那么有很多种方式,这边给出一种脚本方式处理。 通过持续监控,当发现活动窗口不是我们所希望的窗口时,将我们希望置顶的程序窗口置顶。 脚本 …