当前位置: 首页 > news >正文

【后端】乐观锁和悲观锁

前置知识点

锁:一种确保数据安全的机制和手段。

在多个线程修改共享变量时,我们可以对修改操作进行加锁。当多个用户修改表中的同一数据时,我们可以对该行数据进行加锁(行锁)。锁是用于控制多个操作在并发环境下按顺序执行,以确保数据安全。

我们在数据库中使用的是MySQL,而MySQL中最常用的存储引擎是InnoDB。InnoDB默认使用行锁。行锁是基于索引的,因此在加锁时必须命中索引,否则将使用表锁。

乐观锁

它认为数据的变动不会过于频繁,因此允许多个事务同时对数据进行修改。乐观锁通常通过在表中添加一个版本号(version)或时间戳(timestamp)来实现,其中版本号是最常用的方法。当事务从数据库中获取数据时,会同时获取该数据的版本号。当事务完成对数据的修改并尝试将其更新到表中时,会将之前获取到的版本号v1与数据当前的最新版本号v2进行比较。如果v1等于v2,说明在数据变动期间没有其他事务对数据进行修改,此时允许事务修改表中的数据,并且更新后的版本号会加1,表示数据已经变动过。如果v1不等于v2,说明在数据变动期间数据被其他事务修改了,此时不允许将数据更新到表中。一般的处理方法是通知用户重新进行操作。与悲观锁不同,乐观锁是由人为控制的。

悲观锁

乐观锁是一种悲观的锁。这种悲观情绪体现在哪里呢?悲观本质上是一种消极的情绪,当锁采用悲观策略时,它认为被保护的数据是极度不安全的,随时可能被改变。当一个事务获得悲观锁后,其他任何事务都不能对该数据进行修改,只能等待锁被释放才能执行。

在数据库中,行锁、表锁、读锁、写锁以及使用同步(synchronized)实现的锁,都属于悲观锁的范畴。 😭

总结

悲观锁:
由于悲观锁可能对系统的吞吐性能造成影响,因此它更适合应用于写操作较多的场景。

乐观锁:
乐观锁的设计目的是为了避免悲观锁带来的缺点,因此更适合应用于读操作较多的场景。

http://www.lryc.cn/news/292401.html

相关文章:

  • 软件工程知识梳理1-可行性研究
  • 2024美国大学生数学建模E题财产保险的可持续模型详解思路+具体代码
  • pytorch nearest upsample整数型tensor
  • MySQL的SQL MODE
  • GO EASY 框架 之 NET 05
  • 【教程】谈一谈 IPA 上传到 App Store Connect 的几种方法
  • 面试经典 150 题 -- 滑动窗口 (总结)
  • JDK8对List对象根据属性排序
  • 【2024美国大学生数学建模竞赛】2024美赛C题网球运动中的势头,网球教练4.0没人比我更懂这个题了!!!
  • python的Flask生产环境部署说明照做成功
  • EXCEL VBA调用百度api识别身份证
  • 【每日一题】7.LeetCode——合并两个有序链表
  • 【零基础学习CAPL】——CAN报文的发送(按下按钮同时周期性发送)
  • 六、Nacos源码系列:Nacos健康检查
  • 2024美赛C题思路/代码:网球中的动量
  • ConcurrentHashMap原理详解(太细了)
  • EasyExcel根据对应的实体类模板完成多个sheet的写入与读取
  • 在企业数字化转型过程中,IT运维发挥着怎样的价值?
  • 01-工厂模式 ( Factory Pattern )
  • 【LeetCode】每日一题 2024_2_2 石子游戏 VI(排序、贪心)
  • 一站式在线协作开源办公软件ONLYOFFICE,协作更安全更便捷
  • Java进击框架:Spring-综合(十)
  • 2024年第九届信号与图像处理国际会议(ICSIP 2024)
  • webassembly003 MINISIT mnist/convert-h5-to-ggml.py
  • fetch和axios的区别
  • 【unity小技巧】FPS简单的射击换挡瞄准动画控制
  • 如何获取时间戳
  • VSCode 设置代理
  • 保姆级教程: 零门槛制作AI微信红包封面之入门篇
  • Redis核心技术与实战【学习笔记】 - 17.Redis 缓存异常:缓存雪崩、击穿、穿透