mysql 的乐观锁和 mvcc 是一回事吗

devtools/2024/11/20 18:50:10/

MySQL 的乐观锁和 MVCC(多版本并发控制)是两个不同的概念,尽管它们都涉及到并发控制和数据的一致性,但在设计目的和实现方式上存在本质区别。


1. 乐观锁

  • 概念
    乐观锁是一种用于解决并发更新冲突的控制机制。它假设数据在大部分情况下不会发生冲突,因此允许多个事务自由读取数据,只有在更新时才进行冲突检测。

  • 实现方式
    乐观锁通常通过应用层实现,依赖特定的字段(如版本号或时间戳)来判断数据是否被其他事务修改过:

    1. 读取数据时,获取一个版本号或时间戳。
    2. 更新数据时,检查版本号是否与读取时一致。如果一致,更新并将版本号加1;否则,事务失败或重试。
  • 优点

    • 适用于读多写少的场景,冲突较少时性能较高。
    • 简单易实现,不需要复杂的锁机制。
  • 缺点

    • 在高并发下写入冲突多时,重试成本较高。
  • 示例(SQL 版本控制)

-- 更新时检查版本号是否一致
UPDATE table_name
SET value = 'new_value', version = version + 1
WHERE id = 1 AND version = 5;

如果 version 不匹配,则表示数据已被修改,更新失败。


2. MVCC(多版本并发控制)

  • 概念
    MVCC 是一种数据库引擎内部实现的并发控制机制。它通过维护数据的多个版本来支持高并发事务,使读操作和写操作之间不直接阻塞。

  • 实现方式(在 MySQL 中)

    • MySQL 的 InnoDB 存储引擎通过 undo log 和事务快照实现 MVCC。
    • 每个事务根据其开始的快照读取数据,这样即使其他事务更新了数据,当前事务依然可以看到之前的版本。
    • MVCC 依赖于 READ COMMITTEDREPEATABLE READ 的隔离级别。
  • 优点

    • 提高了并发性能,读操作不会阻塞写操作。
    • 提供一致性视图(事务内看到的是一致的快照数据)。
  • 缺点

    • 内部实现复杂,可能导致额外的存储开销。
  • 示例

    • 在事务 A 中查询时可以看到事务开始时的快照,即使事务 B 更新了数据,事务 A 的视图不会改变。

对比总结

特性乐观锁MVCC
适用范围应用层、特定场景数据库存储引擎级别
实现方式通过版本号或时间戳控制冲突多版本管理,通过 undo log 实现
优点简单高效,适用于读多写少场景高并发读写性能,不需要显式加锁
缺点写多冲突时重试成本高需要额外的存储和性能开销
冲突检测更新时显式检测数据库引擎内部管理冲突

结论

不是一回事

乐观锁是更高层的并发控制策略,通常在应用层实现,用于显式地解决数据更新冲突。而 MVCC 是数据库存储引擎内部的一种实现机制,旨在优化事务的读写性能。

尽管它们都关注并发问题,但它们的应用场景和实现方式不同,可以结合使用。例如,在 MySQL 中使用 MVCC 提供一致性视图,同时在业务层用乐观锁控制特定场景下的冲突。


http://www.ppmy.cn/devtools/135550.html

相关文章

【知识堂】奇点

“奇点”在不同领域有不同的含义。以下是几个常见的定义: 1. 数学中的奇点 在数学中,“奇点”通常指的是一个函数、曲线或空间中表现出不正常行为的点。在更详细的层面,奇点是指某个数学对象在该点附近无法用常规的数学工具来描述或者解析。…

【一句话经验】亚马逊云EC2 ubuntu24.04.1开启ROOT登录Permission denied (publickey)

按照常规的方法SSH登录会一直报错: Permission denied (publickey) 因为亚马逊云的默认配置不是在/etc/ssh/sshd_config,而是在引入的文件里了,所以在instance控制台输入这行命令来解除登录限制: sudo sed -i s/^PasswordAuthe…

C++Qt编写校园导航系统

系统要求 (1)有界面, 显示各个景点以及景点之间的路径和路径长度,边上有几个按钮和文本框,在文本框中输入遍历的起点,输入就最短路径的起点和终点, 点击按钮后在界面上用不同颜色标注出路径或铺…

Android OpenGL ES详解——Renderer接口介绍

OpenGL是一个跨平台的图形库,用于渲染2D和3D图形。在Android上,使用OpenGL可以创建高性能的图形应用程序,包括游戏、模拟器、虚拟现实应用等。 Android中使用OpenGL的一般步骤如下: 初始化OpenGL环境:在Activity的onC…

nfs服务器--RHCE

一,简介 NFS(Network File System,网络文件系统)是FreeBSD支持的文件系统中的一种,它允许网络中的计 算机(不同的计算机、不同的操作系统)之间通过TCP/IP网络共享资源,主要在unix系…

【SQL】E-R模型(实体-联系模型)

目录 一、介绍 1、实体集 定义和性质 属性 E-R图表示 2. 联系集 定义和性质 属性 E-R图表示 一、介绍 实体-联系数据模型(E-R数据模型)被开发来方便数据库的设计,它是通过允许定义代表数据库全局逻辑结构的企业模式&#xf…

利用MQTT和SSL/TLS实现数据加密

随着物联网(IoT)技术的飞速发展,越来越多的设备接入网络,进行数据交换和处理。在这个过程中,确保数据传输的安全性成为了至关重要的环节。本文将介绍如何利用MQTT协议和SSL/TLS加密技术,构建安全的物联网通…

如何利用virtualenv和python命令创建Python虚拟环境

一、引言 创建Python虚拟环境可以利用多种方法来实现,如:Anaconda3、Miniconda、virtualenv以及python自带的命令(python -m )进行创建。 Anaconda3、Miniconda创建python虚拟环境时,主机必须要接入互联网远程channel中取下下载需要的包才可…