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

乐观锁 or 悲观锁 你怎么选?

你有没有听过这样一句话:悲观者正确,乐观者成功​。那么今天我来分享下什么是乐观锁​和悲观锁。

2c1afc4fa657c97734003819c0785be2

乐观锁和悲观锁有什么区别,它们什么场景会用

乐观锁

乐观锁基于这样的假设:多个事务在同一时间对同一数据对象进行操作的可能性很小,因此它允许多个事务同时进行,仅在事务提交时检查是否有其他事务对数据进行了修改。

特点

  • 无锁:乐观锁通常不使用数据库的锁定机制,而是通过其他方式(如时间戳、版本号)来确保数据一致性。
  • 性能:在冲突较少的情况下,乐观锁可以提供更好的性能,因为它允许高并发。
  • 冲突检测:在事务提交时检测冲突,如果检测到冲突,事务将被回滚。

实现方式

  • 版本号:在数据表中添加一个版本号字段或时间戳字段。事务开始时记录版本号,提交时检查版本号是否发生变化,如果变化了,则表示有冲突。
  • 时间戳:使用时间戳来控制事务的顺序,如果检测到时间戳冲突,则回滚事务。

适用场景

  • 写冲突较少:适用于写操作不频繁或者写冲突可能性较低的场景。
  • 读多写少:适用于读操作远多于写操作的环境。
  • 高并发:需要支持高并发访问的系统。

悲观锁

悲观锁基于这样的假设:多个事务对同一数据对象的并发操作会产生冲突,因此它在事务开始时就对数据对象加锁,直到事务结束才释放锁。

特点

  • 锁定:悲观锁通过数据库的锁定机制来确保数据一致性,如行锁或表锁。
  • 性能:在高冲突环境下,悲观锁可能导致更多的等待和锁竞争,从而影响性能。
  • 预防冲突:通过锁定机制预防冲突,而不是检测冲突。

实现方式

  • 显式锁定:使用数据库的锁定命令(如SELECT ... FOR UPDATE)来显式地锁定需要的资源。
  • 隐式锁定:通过数据库事务的隔离级别隐式地实现锁定。

适用场景

  • 写冲突较多:适用于写操作频繁或者写冲突可能性较高的场景。
  • 写多读少:适用于写操作多于读操作的环境。
  • 数据一致性要求高:需要严格保证数据一致性的场合。
http://www.lryc.cn/news/359288.html

相关文章:

  • 《庆余年算法番外篇》:范闲通过最短路径算法在阻止黑骑截杀林相
  • 大一C语言课设 服装销售系统 代码实现与项目总结
  • 从新手到专家:深入探索JVM垃圾回收--开端篇
  • R可视化:另类的柱状图
  • Docker的数据管理(数据卷+数据卷容器)
  • 字符串-至多包含K种字符的子串中最长子串(mid)
  • Docker从安装开始精通
  • MFC:初步理解序列化与反序列化(含代码实现)
  • python程序控制结构
  • 【GD32】04 - Timer定时器
  • Golang | Leetcode Golang题解之第123题买卖股票的最佳时机III
  • Leetcode2028. 找出缺失的观测数据
  • 如何在CentOS中合理划分磁盘空间以优化系统性能
  • 算法(十一)贪婪算法
  • Rust之函数式语言特性:迭代器和闭包(一):概述
  • 配置资源管理
  • unity2020打包webGL时卡进程问题
  • 云原生架构相关技术_3.无服务器技术
  • Leetcode:Z 字形变换
  • Python 3 判断文件是否存在
  • (深度学习记录)第TR3周:Transformer 算法详解
  • 谷神前端组件增强:自定义列
  • 31-ESP32-S3-WIFI篇-02 Event Group (事件标记组)
  • 构建企业级AI私有知识库
  • C语言王国——杨氏矩阵
  • 陪玩小程序都需要怎么做?
  • postgressql——子事务可见性判断 性能问题(8)
  • 20240531在飞凌的OK3588-C开发板上跑原厂的Buildroot测试USB摄像头
  • 从0开始学统计-什么是回归?
  • Element-ui使用上传时弹框选择文件类型