自学内容网 自学内容网

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

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 提供一致性视图,同时在业务层用乐观锁控制特定场景下的冲突。


原文地址:https://blog.csdn.net/u010720890/article/details/143843338

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!