乐观锁的简单感悟

乐观锁(Optimistic Locking)是一种并发控制机制,用于解决多个线程或进程同时访问共享资源时可能发生的冲突问题。与悲观锁不同,乐观锁假设冲突很少发生,因此不会对整个操作过程进行严格的加锁。

乐观锁的实现方式通常有以下几种:

版本号(Versioning): 在数据表中增加一个版本号字段,每次更新数据时,版本号会随之增加。在进行数据更新时,检查当前的版本号是否与自己持有的版本号一致,若一致则进行更新,否则表示已经有其他线程修改了数据。

时间戳(Timestamp): 类似于版本号,但是使用时间戳来标记数据的更新时间。每次更新数据时,将当前时间戳写入数据表中,更新时检查时间戳是否一致。

CAS(Compare and Swap): 使用原子操作的方式进行比较和交换。在更新数据时,比较当前值与期望值是否一致,如果一致则进行交换操作,否则表示已经有其他线程修改了数据。


对于常规博客介绍乐观锁可能就止步于此了其实他们并没有真正讲清楚至关重要的问题;也就是实现的技术细节在哪里?
我个人观点,实现这个技术操作的核心在于乐观锁的思想。

乐观锁的基本思想是,在进行并发操作之前,先获取数据的版本或时间戳信息。当多个线程或进程同时访问相同的数据时,各自会获取到当前的版本或时间戳,并在操作完成后,比较自己的版本或时间戳与数据库中的版本或时间戳是否一致(关键一步,这一步必须是原子性的)。

我们可以分析到,无论是CAS,或者说是数据库层面上的基于版本号控制,其实都有一个关键技术,就是要确保修改的原子性,在读取这个版本号(比较期望值)或者说是读取内存中的值(比较期望值),之后如果判断成功是,则开始尝试去修改它,而修改这个操作需要是原子性的;CAS可以保证原子性,而数据库的update操作也是可以保证原子性;所以乐观锁才得以实现;都是需要基于底层提供的原子操作最终实现的乐观锁操作;

相关推荐

  1. 乐观简单感悟

    2024-03-30 21:34:05       21 阅读
  2. Go语言中乐观与悲观

    2024-03-30 21:34:05       46 阅读
  3. 深度解析乐观

    2024-03-30 21:34:05       31 阅读
  4. 乐观与悲观

    2024-03-30 21:34:05       20 阅读
  5. 乐观和悲观

    2024-03-30 21:34:05       12 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-30 21:34:05       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-30 21:34:05       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-30 21:34:05       20 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-30 21:34:05       20 阅读

热门阅读

  1. 【python】一些常用的小脚本

    2024-03-30 21:34:05       20 阅读
  2. 大三实习小菜蛋之document元素节点

    2024-03-30 21:34:05       17 阅读
  3. Express

    Express

    2024-03-30 21:34:05      18 阅读
  4. C++知识点总结(27):链表

    2024-03-30 21:34:05       16 阅读
  5. math模块篇(八)

    2024-03-30 21:34:05       16 阅读
  6. vue 通过插槽来分配内容

    2024-03-30 21:34:05       15 阅读
  7. SQL中添加数据的方式

    2024-03-30 21:34:05       14 阅读
  8. 基于IvorySQL+Patroni+vip-manager构建高可用集群

    2024-03-30 21:34:05       15 阅读
  9. Flutter页面生命周期

    2024-03-30 21:34:05       16 阅读
  10. 『C++初阶』第一章-命名空间与缺省参数

    2024-03-30 21:34:05       16 阅读