Mysql--技术文档--悲观锁、乐观锁-《控制并发机制简单认知、深度理解》

这篇具有很好参考价值的文章主要介绍了Mysql--技术文档--悲观锁、乐观锁-《控制并发机制简单认知、深度理解》。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

阿丹:

        首先在谈到并发控制机制的时候,我们通常会提及两种重要的锁策略。悲观锁(Pessimistic Locking)和乐观锁(Optimistic Locking)。这两个是在处理并发的时候采取的不同思路。

悲观锁:

        悲观锁: 悲观锁机制认为并发操作中会有冲突,因此默认情况下假设会出现并发冲突,因此采取阻止或延迟访问的方式来保证一致性和隔离性。悲观锁的基本思想是,在数据的访问和修改过程中,假设其他事务会对该数据进行修改,因此在操作数据之前,先获取锁来保护资源的完整性。

当一个事务试图获取悲观锁时,它会将资源标记为已锁定状态,其他事务如果要访问该资源,必须等待锁释放。这种锁定通常是独占锁,在锁被持有期间,其他事务无法读取或修改数据,从而保证了数据的一致性和隔离性。悲观锁常用的实现方式是加锁机制,如共享锁(Shared Lock)和排他锁(Exclusive Lock)。

阿丹解读:

        就是悲观锁认为所有的资源都要使用我这个,然后当我在执行一个事务的时候,我就给所有的东西锁死了。一直到我解决完了当前的事务别人才能从我这里访问资源。如果我在锁上的时候啥我都不给。悲观锁说我要保证一致性,所以就进行了独占锁(排他锁)。来解决冲突。

乐观锁

        乐观锁: 乐观锁机制则采取了一种更加乐观的假设,它认为并发操作中冲突的概率较低。乐观锁的基本思想是,在操作数据之前,不会加锁,也不会阻止其他事务的并发访问。相反,事务在进行修改前,会先获取数据的一个快照或版本,并在操作完成时对数据进行一致性验证。

        在乐观锁中,每个事务通常会关联一个版本号、时间戳或序列号,这些信息用于识别数据的版本。在读取和修改数据时,事务会使用这些信息来验证数据是否被其他事务修改过。如果数据的版本与事务启动时的版本一致,则可以继续操作;如果版本不一致,说明在操作过程中数据已被修改,乐观锁机制会回滚事务或触发相应的冲突处理逻辑。

        乐观锁常用的实现方式包括添加额外的字段来记录版本信息,例如在数据库中添加一个版本号字段或使用时间戳来标记数据的更新时间。

        悲观锁和乐观锁各有优缺点,适用于不同的场景。悲观锁机制保证了数据的强一致性和隔离性,但可能导致较高的锁冲突和性能开销。乐观锁机制允许更高的并发性能,但需要应用程序代码对冲突进行适当处理,以保证数据的一致性。

阿丹解读:

        乐观锁其实就是在我去进行数据库落库操作之前的之前,谁来读取我都给。因为我在我进行逻辑操作计算的时候保存了一个类似于快照的东西。乐观锁只需要在落库之前对比一下我的数据和快照一样不一样,如果一样就说明我没和别人冲突就正常落库。如果不一样就是在我进行计算的时候有人和我冲突了。我就回滚。

        所以乐观锁只锁了写没有锁读,所以对于其他的事务来说更友好。乐观锁对操作加了锁。

其他的并发控制机制

在数据库系统中,常用的并发控制机制包括以下几种:

  1. 锁机制(Locking):锁机制是最常见、最基本的并发控制机制之一。它通过使用锁来保护共享资源,防止多个事务同时读取或修改同一份数据。锁可以分为共享锁(Shared Lock)和排他锁(Exclusive Lock),以允许读取共享数据或独占修改数据。

  2. 多版本并发控制(MVCC,Multi-Version Concurrency Control):MVCC通过对数据的版本管理来实现并发控制。它为每个事务创建数据的独立版本,并通过版本号或时间戳来识别数据的不同版本,从而避免了读-写冲突和写-写冲突。MVCC通常使用乐观锁来进行并发控制。

  3. 串行化(Serializability):串行化是一种较为保守的并发控制机制,它确保事务以串行的方式执行,从而避免了并发冲突。串行化通常使用锁机制、时间戳或序列号等方式来实现,但由于事务的串行执行,可能会导致性能瓶颈。

  4. 快照隔离(Snapshot Isolation):快照隔离是一种基于版本管理的并发控制机制,它为每个事务提供一个快照(Snapshot)来读取数据。每个事务在开始时读取数据的快照,并在事务提交时进行验证。快照隔离提供了较高的并发性能和隔离性,但可能导致一些读取操作的不一致性。

  5. 时间戳排序(Timestamp Ordering):时间戳排序是一种并发控制机制,它通过为每个事务分配全局唯一的时间戳来实现。事务按时间戳的先后顺序执行,从而避免了并发冲突。时间戳排序通常需要一个中心时钟或全局时钟来生成时间戳。文章来源地址https://www.toymoban.com/news/detail-686444.html

到了这里,关于Mysql--技术文档--悲观锁、乐观锁-《控制并发机制简单认知、深度理解》的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MySQL实战:解密乐观并发控制,确保数据操作不冲突

      概述: 乐观并发控制是处理数据访问并发的一种策略,通过在更新前检查版本号或时间戳,确保数据在事务间保持一致性。在MySQL示例中,通过比对版本号,如果发现其他事务已更新数据,则拒绝当前事务的修改,避免潜在的并发冲突。这种机制提高了数据一致性,典型应

    2024年03月13日
    浏览(25)
  • MySQL乐观锁与悲观锁

    遇见并发情况,需要保证数据的准确性,也就是与正确的预期一致,此时就会用到锁。 锁是在并发下控制程序的执行逻辑,以此来保证数据按照预期变动。 如果不加锁,并发情况下的可能数据不一致的情况,这是个概率问题。 乐观锁很乐观,假设数据一般情况不会造成冲突

    2024年01月23日
    浏览(26)
  • Mysql--技术文档--B+树-数据结构的认知

    之前的文章中写道了有关mysql底层索引,那么在数据量特别大的情况下。mysql采用了B+来管理索引。和存储的数据。 Mysql--技术文档--索引-《索引为什么查找数据快?》-超底层详细说明索引_一单成的博客-CSDN博客 B树解读: Mysql--技术文档--B树-数据结构的认知_一单成的博客-CS

    2024年02月09日
    浏览(31)
  • 如何在 EF Core 中使用乐观并发控制

    乐观并发控制是一种处理并发访问的数据的方法,它基于一种乐观的假设,即认为并发访问的数据冲突的概率很低。在乐观并发控制中,系统不会立即对并发访问的数据进行加锁,而是在数据被修改时,再检查是否有其他并发操作已经修改了数据。如果检测到冲突,系统 再采

    2024年02月04日
    浏览(32)
  • Flutter--常用技术文档

    配置 清华大学flutter镜像 export PUB_HOSTED_URL=https://mirrors.tuna.tsinghua.edu.cn/dart-pub export FLUTTER_STORAGE_BASE_URL=https://mirrors.tuna.tsinghua.edu.cn/flutter 社区镜象 export PUB_HOSTED_URL=https://pub.flutter-io.cn export FLUTTER_STORAGE_BASE_URL=https://storage.flutter-io.cn 混合开发 问题 解决 iOS、Flutter混合开发 ➜ Na

    2024年01月16日
    浏览(50)
  • 云笔记技术文档

    定义实体 定义对数据库中User相关数据的操作 UserMapper.xml 定义了更新密码,通过ID寻找User,通过name寻找User,添加User操作 创建Dao层接口连接上述操作 在Service层进行具体的功能实现 在Service层,实现了修改密码,登录,注册功能 接口:UserService.java 实现:UserServicelmpl.java 在C

    2024年02月15日
    浏览(46)
  • Prometheus技术文档-概念

     Prometheus是一个开源的项目连接如下: Prometheus首页、文档和下载 - 服务监控系统 - OSCHINA - 中文开源技术交流社区           Prometheus是一个开源的系统监控和告警系统,由Google的BorgMon监控系统发展而来。它主要用于监控和度量各种时间序列数据,比如系统性能、网络延迟

    2024年02月14日
    浏览(40)
  • 海康web插件技术文档

    前情提要:本技术文档基于我司石衡项目视频监控页面的应用进行总结。 石衡项目是基于vue2,使用Element-ui + 海康web插件 + Echarts + GIS的集成项目。 视频监控实现的主要功能: 路段中所有摄像头树状显示和检索 双击摄像头进行画面预览查看 预览模式和回放模式的切换

    2024年02月09日
    浏览(61)
  • kafka--技术文档--架构体系

    Kafka的架构体系包括以下几个部分: Producer.  消息生产者,就是向Kafka broker发送消息的客户端。 Broker.  一台Kafka服务器就是一个Broker。一个集群由多个Broker组成。一个Broker可以容纳多个Topic。 Topic.  可以理解为一个队列,一个Topic又分为一个或多个Partition。 Partition.  为了实

    2024年02月11日
    浏览(36)
  • 【前沿技术杂谈:多模态文档基础模型】使用多模态文档基础模型彻底改变文档 AI

    您是否曾经被包含不同信息(如应付账款、日期、商品数量、单价和金额)的发票所淹没?在处理重要的商业合同时,您是否担心小数点后点错误,造成无法估量的经济损失?您是否在寻找顶尖人才时阅读过大量简历?商务人士必须处理所有这些任务和各种各样的文件,包括

    2024年02月21日
    浏览(42)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包