• 乐观离线锁


    乐观离线锁最常见的实现方式是通过在UPDATE/DELETE语句中增加版本号来实现锁机制。

    之所以叫离线锁是因为这种锁不是长时间的锁,而且一个业务事务中可能同时包含了几个系统事务。而乐观是相对悲观而言的,表示预计冲突不总是发生,以其得到最大的性能。

    可能对业务事务,系统事务的概念大家有些陌生。按我的理解,可以这样解释:首先,你要明白事务不仅仅是一个技术问题(系统事务),更是一个领域问题(业务事务),举例说明,我们编辑一篇文章,显示编辑页面的动作可能涉及一个系统事务,提交表单的时候又涉及了一个系统事务,而整体可以看成一个业务事务。

    如果不使用锁,那么就会产生不一致问题,如两个人一起编辑同一个文章,后一个提交的人就会覆盖前一个人的修改。

    使用悲观离线锁似乎不错,我们可以在表里加一个字段表示当前记录是否被锁定,当显示编辑界面的时候就立刻设定为锁定,阻止其他人编辑,然后当提交的时候再解锁,看上去很美,但这个方法有很多问题,比如:打开编辑界面,记录标记为锁定,然后因为某些原因关闭了浏览器,问题出现了,记录将一直处于锁定状态。

    使用乐观离线锁可以解决这个问题,通过在文章表里加入一个version字段,编辑之初从数据库中取出此值,保存在session中,编辑结束后UPDATE version = version + 1, ... WHERE version = ...来确保一致性,如果之前已经有人提交了,则version已经加一,那么再使用session里的version值进行比较,WHERE version = ... 将不再成立,影响行数为0,数据库回滚。

  • 相关阅读:
    JAVA学习日记1-0706
    同步一个fork
    面试题 17.13. 恢复空格-7月9日
    3. 无重复字符的最长子串(leetcode)-7月8日
    面试题 16.11. 跳水板(leetcode)-7月8日
    112.路径总和(leetcode)-7月7日
    Git使用入门
    第一次尝试
    OpenPCDet: Open-MMLab 面向LiDAR点云表征的3D目标检测代码库
    人工智能和机器学习能为抗击新冠肺炎做些什么?
  • 原文地址:https://www.cnblogs.com/lixiaoran/p/6650382.html
Copyright © 2020-2023  润新知