当前位置:首页 > 科技  > 软件

聊聊乐观锁与悲观锁

来源: 责编: 时间:2024-05-17 17:48:33 126观看
导读悲观锁在MySQL中,悲观锁依赖数据库提供的锁机制来实现。在InnoDB引擎中,使用悲观锁需要先关闭MySQL数据库的自动提交属性,然后通过select ... for update来进行加锁。在数据库中,悲观锁的流程如下:• 在对记录进行修改前,先

悲观锁

在MySQL中,悲观锁依赖数据库提供的锁机制来实现。在InnoDB引擎中,使用悲观锁需要先关闭MySQL数据库的自动提交属性,然后通过select ... for update来进行加锁。Emx28资讯网——每日最新资讯28at.com

在数据库中,悲观锁的流程如下:Emx28资讯网——每日最新资讯28at.com

• 在对记录进行修改前,先尝试为该记录加上排他锁(exclusive lock)。Emx28资讯网——每日最新资讯28at.com

• 如果加锁失败,说明该记录正在被修改,此时当前查询可能需要等待或抛出异常,具体响应方式由开发者根据实际需求决定。Emx28资讯网——每日最新资讯28at.com

• 如果成功加锁,则可以对记录进行修改,事务完成后锁将被释放。Emx28资讯网——每日最新资讯28at.com

• 其间若有其他操作试图对该记录进行修改或加排他锁,则会等待当前锁的释放或直接抛出异常。Emx28资讯网——每日最新资讯28at.com

我们以电商平台下单过程中扣减库存的需求为例,说明如何使用悲观锁:Emx28资讯网——每日最新资讯28at.com

-- 0.开始事务begin; -- 1.查询出商品信息SELECT stock FROM products WHERE product_id = 12345 FOR UPDATE;-- 2.修改商品stock为2update products set stock=2 where product_id = 12345;-- 3.提交事务commit;

在对id=1的记录进行修改前,先通过FOR UPDATE的方式加锁,然后再进行修改。这就是典型的悲观锁策略。Emx28资讯网——每日最新资讯28at.com

如果上述修改库存的代码发生并发,同一时间只有一个线程可以开启事务并获得id=1的锁,其他事务必须等本次事务提交之后才能执行。这样,我们可以保证当前的数据不会被其他事务修改。Emx28资讯网——每日最新资讯28at.com

上面提到,使用SELECT ... FOR UPDATE会将数据锁住,不过我们需要注意一些锁的级别。MySQL InnoDB默认使用行级锁。行级锁都是基于索引的,如果一条SQL语句未使用索引,优化器在选择时,若发现锁表可能性能更好,有可能会直接锁表。Emx28资讯网——每日最新资讯28at.com

上面这个点之前也有在文章提到过: Emx28资讯网——每日最新资讯28at.com

日活3kw的实际库存业务场景中的超卖到底怎么解决的Emx28资讯网——每日最新资讯28at.com

感兴趣的可以参考阅读一下,希望对你有所帮助Emx28资讯网——每日最新资讯28at.com

乐观锁

MySQL中的乐观锁主要通过CAS(Compare and Swap)的机制来实现,通常使用版本号(version)来实现。Emx28资讯网——每日最新资讯28at.com

CAS是一种乐观锁技术,当多个线程尝试使用CAS同时更新同一个变量时,只有其中一个线程能成功更新变量的值,而其他线程都失败。失败的线程并不会被挂起,而是被告知在此次竞争中失败,并可以再次尝试。Emx28资讯网——每日最新资讯28at.com

以扣减库存为例,通过乐观锁可以实现如下:Emx28资讯网——每日最新资讯28at.com

-- 查询出商品信息,stock = 3select stock from products product_id id= 1-- 根据商品信息生成订单-- 修改商品stock为2update products set stock=2 where id=1 and stock = 3;

以上,在更新之前,先查询库存表中当前的库存数(stock),然后在执行更新时,将库存数作为修改条件。提交更新时,对比数据库表记录的当前库存数与第一次查询得到的库存数,若两者相等,则执行更新;否则,视为数据已过期。Emx28资讯网——每日最新资讯28at.com

题外话

悲观锁

在对数据库中的数据进行修改时,为了避免同时被其他人修改,最好的方法是直接对该数据进行加锁以防止并发。这种在修改数据之前先锁定再修改的方式被称为悲观并发控制(又称“悲观锁”,Pessimistic Concurrency Control,缩写为“PCC”)。Emx28资讯网——每日最新资讯28at.com

悲观锁之所以被称为悲观,是因为这是一种对数据的修改抱有悲观态度的并发控制方式。一般来说,我们认为数据被并发修改的概率较大,因此在修改之前先加锁。Emx28资讯网——每日最新资讯28at.com

悲观并发控制实际上是一种保守的策略,即“先取锁再访问”,它为数据处理的安全性提供了保证。Emx28资讯网——每日最新资讯28at.com

图片图片Emx28资讯网——每日最新资讯28at.com

在效率方面,处理加锁机制会导致数据库产生额外的开销,增加了产生死锁的风险。此外,悲观锁还可能降低并行性,因为如果一个事务锁定了某行数据,其他事务就必须等待该事务完成才能处理该行数据。Emx28资讯网——每日最新资讯28at.com

乐观锁

乐观锁(Optimistic Locking)是相对悲观锁而言的。乐观锁假设数据在一般情况下不会发生冲突,因此在数据提交更新时才会实际检查数据是否冲突。如果发现冲突,则会向用户返回错误信息,让用户决定如何处理。Emx28资讯网——每日最新资讯28at.com

与悲观锁相比,乐观锁在处理数据库时并不会使用数据库提供的锁机制。一般来说,乐观锁的实现方式是通过记录数据的版本信息。Emx28资讯网——每日最新资讯28at.com

图片图片Emx28资讯网——每日最新资讯28at.com

乐观并发控制相信事务之间的数据竞争(data race)的概率较小,因此尽可能直接进行操作,直到提交时才对数据进行检查和锁定。这样做不会产生任何锁或死锁。Emx28资讯网——每日最新资讯28at.com

如何选择

在乐观锁与悲观锁的选择上面,主要看下两者的区别以及适用场景就可以了。Emx28资讯网——每日最新资讯28at.com

1. 乐观锁并未真正加锁,效率高。适用于读操作频繁,写操作相对较少的场景。一旦锁的粒度掌握不好,更新失败的概率就会比较高,容易发生业务失败。Emx28资讯网——每日最新资讯28at.com

2. 悲观锁依赖数据库锁,效率低。更新失败的概率比较低。适用于写操作较为频繁,且并发写入的概率较高的场景。Emx28资讯网——每日最新资讯28at.com

根据以上区别和场景特点,可以针对具体业务需求选择合适的并发控制策略。当然最多的场景其实当属于高并发场景如何选择。Emx28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-88933-0.html聊聊乐观锁与悲观锁

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Spring注入还可以这样玩!涨知识了

下一篇: 谁说PHP不能异步和并行运行?

标签:
  • 热门焦点
  • 石头智能洗地机A10 Plus体验:双向自清洁治好了我的懒癌

    石头智能洗地机A10 Plus体验:双向自清洁治好了我的懒癌

    一、前言和介绍专为家庭请假懒人而生的石头科技在近日又带来了自己的全新旗舰新品,石头智能洗地机A10 Plus。从这个产品名上就不难看出,这次石头推出的并不是常见的扫地机器
  • vivo TWS Air开箱体验:真轻 臻好听

    vivo TWS Air开箱体验:真轻 臻好听

    在vivo S15系列新机的发布会上,vivo的最新款真无线蓝牙耳机vivo TWS Air也一同发布,本次就这款耳机新品给大家带来一个简单的分享。外包装盒上,vivo TWS Air保持了vivo自家产
  • Raft算法:保障分布式系统共识的稳健之道

    Raft算法:保障分布式系统共识的稳健之道

    1. 什么是Raft算法?Raft 是英文”Reliable、Replicated、Redundant、And Fault-Tolerant”(“可靠、可复制、可冗余、可容错”)的首字母缩写。Raft算法是一种用于在分布式系统
  • 一文搞定Java NIO,以及各种奇葩流

    一文搞定Java NIO,以及各种奇葩流

    大家好,我是哪吒。很多朋友问我,如何才能学好IO流,对各种流的概念,云里雾里的,不求甚解。用到的时候,现百度,功能虽然实现了,但是为什么用这个?不知道。更别说效率问题了~下次再遇到,
  • 猿辅导与新东方的两种“归途”

    猿辅导与新东方的两种“归途”

    作者|卓心月 出品|零态LT(ID:LingTai_LT)如何成为一家伟大企业?答案一定是对“势”的把握,这其中最关键的当属对企业战略的制定,且能够站在未来看现在,即使这其中的
  • 当家的盒马,加速谋生

    当家的盒马,加速谋生

    来源 | 价值星球Planet作者 | 归去来自己“当家”的盒马,开始加速谋生了。据盒马官微消息,盒马计划今年开放生鲜供应链,将其生鲜商品送往食堂。目前,盒马在上海已经与
  • 冯提莫签约抖音公会 前“斗鱼一姐”消失在直播间

    冯提莫签约抖音公会 前“斗鱼一姐”消失在直播间

    来源:直播观察提起“冯提莫”这个名字,很多网友或许听过,但应该不记得她是哪位主播了。其实,作为曾经的“斗鱼一姐”,冯提莫在游戏直播的年代影响力不输于现
  • 7月4日见!iQOO 11S官宣:“鸡血版”骁龙8 Gen2+200W快充加持

    7月4日见!iQOO 11S官宣:“鸡血版”骁龙8 Gen2+200W快充加持

    上半年已接近尾声,截至目前各大品牌旗下的顶级旗舰都已悉数亮相,而下半年即将推出的顶级旗舰已经成为了数码圈爆料的主流,其中就包括全新的iQOO 11S系
  • Windows 11发布,微软一改往常对老机型开放的态度

    Windows 11发布,微软一改往常对老机型开放的态度

    距离 Windows 11 发布已经过去一周,在过去一周里,很多数码爱好者围绕其对 Android 应用的支持、对老机型的升级问题展开了激烈讨论。与以往不同的是,在这次大
Top