事务隔离通常通过锁定任何对事务中资源的访问来实现的。总的来说,有两种方法针对事务的锁定:乐观锁(Pessimistic locking)和悲观锁(Optimistic locking)

悲观锁(Pessimistic locking)

悲观锁,正如其名,它指的是对数据被外界(包括本系统当前的其他事务,以及来自外部系统的事务处理)修改持保守态度,因此,在整个数据处理过程中,将数据处于锁定状态。悲观锁的实现,往往依靠数据库提供的锁机制 (也只有数据库层提供的锁机制才能真正保证数据访问的排他性,否则,即使在本系统中实现了加锁机制,也无法保证外部系统不会修改数据)。

悲观锁的缺点在于,资源第一次的访问就会被事务锁定,除非事务完成,资源始终是不可访问的。如果大量事务都是仅仅对事务进行检索而不是更新操作,那么这种排它锁会大量阻塞,引起锁的争用。这种情况下,乐观锁会是一种更好的方案。在使用悲观锁的情况下,是通过请求失败来保证并发安全性的。以银行系统为例,一旦一个账户通过事务来访问,那么就会锁定整个账户。其他的事务尝试访问账户都会被延迟,阻塞,直到之前的事务结束(完成或者回滚)。悲观锁会一直存在,直到事务提交或者回滚。

乐观锁( Optimistic Locking )

乐观锁( Optimistic Locking ) 相对悲观锁而言,乐观锁假设认为数据一般情况下不会造成冲突,所以在数据进行提交更新的时候,才会正式对数据的冲突与否进行检测,如果发现冲突了,则让返回用户错误的信息,让用户决定如何去做。那么我们如何实现乐观锁呢,一般来说有以下2种方式:

  • 使用数据版本(Version)记录机制实现,这是乐观锁最常用的一种实现方式。何谓数据版本?即为数据增加一个版本标识,一般是通过为数据库表增加一个数字类型的 “version” 字段来实现。当读取数据时,将version字段的值一同读出,数据每更新一次,对此version值加一。当我们提交更新的时候,判断数据库表对应记录的当前版本信息与第一次取出来的version值进行比对,如果数据库表当前版本号与第一次取出来的version值相等,则予以更新,否则认为是过期数据。
  • 乐观锁定的第二种实现方式和第一种差不多,同样是在需要乐观锁控制的table中增加一个字段,名称无所谓,字段类型使用时间戳(timestamp), 和上面的version类似,也是在更新提交的时候检查当前数据库中数据的时间戳和自己更新前取到的时间戳进行对比,如果一致则OK,否则就是版本冲突。

在使用乐观锁的时候,资源并不会在第一次由事务访问的时候就锁定,相反,资源的状态会使用悲观锁的方式锁定。当其他事务并发的访问资源,并且访问资源的时候,是可能出现冲突的。当提交的时候,资源将要持久化到存储的时候,会重新读取资源的状态,然后对比事务第一次访问的时候所锁定的状态,如果两个状态不同,就会有冲突,从而事务会回滚。

同样以银行应用为例,账户第一次由事务访问的时候,就记录了账户的余额。当事务修改了账户的余额的时候,账户的信息会在执行更新之前再次查询账户的余额。如果余额在事务期间有变化,那么事务就会失败,如果余额没有变化,那么这次修改就会被持久化到存储中。

乐观并发控制(Optimistic concurrency control)

乐观并发控制(OCC)是一种应用到事务系统中的并发控制方法,比如在关系数据库管理系统以及软件事务内存等。OCC的理论依据是多数事务在执行更新的时候,是不会影响到彼此的。在运行时,事务使用资源是不需要获取资源的锁的,但是在提交之前,每个事务都会验证并没有其他的事务在修改数据。如果检查碰到了更新冲突,那么事务的提交会回滚,然后重新执行。

前面提到了OCC的理论依据,所以OCC一般用于低数据冲突的环境。当争用很少的时候,事务就能够几乎不需要付出管理锁的代价,也不需要等待其他事务完成了。这样可以比其它并发控制带来更高的吞吐。当然了,如果数据资源频繁出现争用的话,那么事务的重启就会严重的影响性能了。这个时候使用其他并发控制可能更好。然而,基于锁的方法(悲观锁)在锁定数据的时候,会严重限制并发性能。

转载于:https://www.cnblogs.com/qitian1/p/6461485.html

Pessimistic and Optimistic locking相关推荐

  1. Lock Mode Type 之 Optimistic 使用场景

    JPA规范中,Lock Mode的值中包含了Optimistic, 一看就知道是用于乐观锁控制, 但是我一直被这个问题困扰,原因在于,在Entity中,已经使用@Version做了乐观锁控制,Hibe ...

  2. 面试高频——JUC并发工具包快速上手(超详细总结)

    目录 一.什么是JUC 二.基本知识 2.1.进程和线程 2.2.Java默认有两个进程 2.3.Java能够开启线程吗? 2.4.并发和并行 2.5.线程的状态 2.6.wait和sleep的区别 ...

  3. mysql锁总结知乎_Mysql悲观锁乐观锁区别与使用场景

    概念上区别 乐观锁(Optimistic Locking):顾名思义,对加锁持有一种乐观的态度,即先进行业务操作,不到最后一步不进行加锁,"乐观"的认为加锁一定会成功的,在最后一步 ...

  4. [初级]深入理解乐观锁与悲观锁

    2019独角兽企业重金招聘Python工程师标准>>> 在数据库的锁机制中介绍过,数据库管理系统(DBMS)中的并发控制的任务是确保在多个事务同时存取数据库中同一数据时不破坏事务的隔 ...

  5. 面试题;40个多线程的问题 背1 有用

    Java多线程分类中写了21篇多线程的文章,21篇文章的内容很多,个人认为,学习,内容越多.越杂的知识,越需要进行深刻的总结,这样才能记忆深刻,将知识变成自己的.这篇文章主要是对多线程的问题进行总结的 ...

  6. 一文带你了解 MySQL 中的各种锁机制!

    MySQL中的锁机制,按粒度分为行级锁,页级锁,表级锁,其中按用法还分为共享锁和排他锁. 行级锁 行级锁是Mysql中锁定粒度最细的一种锁,表示只针对当前操作的行进行加锁. 行级锁能大大减少数据库操作 ...

  7. 浅谈数据库乐观锁、悲观锁

    来自:非科班的科班 并发问题 当程序中出现并发的问题时,我们就要有相应的手段保证数据的正确性,防止多个用户在操作数据的时候,出现和预期数据不一样的现象,产生脏数据,在数据库的层面如果没有做好并发控制, ...

  8. 数据库事务的悲观锁和乐观锁

    转载出处:http://www.hollischuang.com/archives/934 在数据库的锁机制中介绍过,数据库管理系统(DBMS)中的并发控制的任务是确保在多个事务同时存取数据库中同一数 ...

  9. mysql 获取距离当前最新的记录_一文带你了解 MySQL 中的各种锁机制!

    云栖号资讯:[点击查看更多行业资讯] 在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来! MySQL中的锁机制,按粒度分为行级锁,页级锁,表级锁,其中按用法还分为共享锁和排他锁. 行级锁 ...

最新文章

  1. Back-propagation, an introduction
  2. 插入排序、选择排序、快速排序以及归并排序(附Python代码)
  3. BJUI验证Input非空和是否为数字
  4. mysql的分片系统_MySQL分片
  5. ENVI入门系列教程---一、数据预处理---4.3自定义RPC文件图像正射校正
  6. 军事指挥系统时间同步解决方案
  7. VueJs 自定义过滤器使用总结
  8. 华为前端社招OD面试(已拿offer)
  9. 数学中的 argmax 和 argmin 什么意思
  10. 虚拟机搭建web服务器
  11. 如何在电脑上安装一个Android虚拟机
  12. php groovy,Groovy
  13. 页面插件集成:博客详情页
  14. 成人世界黑话鉴定指南
  15. cookie注入原理详解
  16. atom 插件下载错误:【Fetching featured packages failed.self signed certificate in certificate chain】
  17. Style.xml的妙用(一)
  18. 设备安全——入侵检测IDS
  19. UNIXLinux操作系统---文件系统
  20. R-概率统计与模拟(三)变换均匀分布对特定分布进行抽样

热门文章

  1. java 泛型 类型实参(type argument)
  2. docker 启动 停止容器
  3. Scala Object
  4. docker 镜像命令
  5. Java click传递变量,Java-OnClickListener中的最终变量要求
  6. Docker学习总结(51)——为什么不建议把数据库部署在 Docker 容器内的7大原因?
  7. Java基础学习总结(152)——JDK 1.7和 JDK 1.8中HashMap的实现有什么不同?
  8. mysql 在线日期_mysql,由 时间点求时间段的问题,在线时间率
  9. java学生奖学金管理系统_EasyUI+JavaWeb奖助学金管理系统[6]-登录功能实现
  10. Android之哭笑不得的BUG--xml设置的padding不起作用,幕后黑手竟然是?