Pessimistic Offline Lock悲观离线锁
每次只允许一个业务事务来访问数据,以防止并发业务事务中的冲突.

- 离线并发处理通常会出现多个业务事务操作同一数据.
- 最简单的办法是为整个业务事务保持一个系统事务.但是事务系统不适合于处理长事务.
- 首选乐观离线锁.
- 而悲观离线锁,作为它的补充.从一开始就避免冲突.
- 它要求业务事务在对数据进行操作前就必须获取该数据的锁.
- 一旦开始了一个业务事务,就确信不会再提交时由于并发冲突而被迫回滚数据.
- 运行机制
- 决定使用哪种锁
- exclusive write lock独占写锁.写目的的会话数据时使用,当对数据的读取要求不高时.
- exclusive read lock独占读锁.仅是为了读目的时的数据.限制了并发性.
- read/write lock读/写锁.
- 读锁和写锁互斥,同一数据记录上只能被附加上一种.
- 允许并发的读锁.读锁会防止其他业务事务修改数据.但是允许其他业务事务读取记录.
- 允许同时读增加了系统的并发性.但是其实现复杂.
- 构建锁管理对象
- 该对象负责授予或者拒绝业务事务获取/释放锁的请求.
- 必须知晓被锁住的资源,和锁的拥有者(业务事务).
- 只能有一张关于锁的表.该表存在于内存或者SQL语句实现的.
- 锁必须是管理对象的私有域.业务事务只能与管理对象交互,而不能直接操作锁对象.
- 定义业务事务使用锁管理对象的协议
- 对什么加锁,
- 通常仅在ID或主键加锁,因为使用它们来查找对象.
- 何时加锁,
- 通常在读取数据之前获取锁.保证加锁的是最新数据时采取加锁.
- 何时释放锁,
- 在业务事务完成时释放.
- 当无法获得锁时的动作.
- 可能会在业务事务一开始就因为无法获取锁而终止事务.
- 对于相互等待对象的锁资源造成的死锁.
- 让锁管理对象在锁不可用时抛出异常即可.直接避免死锁.
- 丢失的会话中锁的超时.Client端在事务进行中崩溃了.
- 让应用服务器的超时机制处理.
- 给每个锁加上时间戳,定时清除超过一定时间的锁.
- 对什么加锁,
- 使用时机
- 适合于冲突率很高的并发会话中.
- 也用于冲突处理代价很高时.
- 它只能作为乐观锁的补充,不推荐使用.
- 可以考虑使用长事务.其实现比悲观锁简单.
Pessimistic Offline Lock悲观离线锁的更多相关文章
- Optimistic Offline Lock乐观离线锁
通过冲突检测和(发生冲突时的)事务回滚,来防止并发业务事务中的冲突. 通常一个业务事务的执行,会跨越一系列的系统事务. 一旦超出了单个系统事务的范围,就不能仅依靠DB管理程序来保证数据一致性. 乐观离 ...
- [转]掌握 ASP.NET 之路:自定义实体类简介 --自定义实体类和DataSet的比较
转自: http://www.microsoft.com/china/msdn/library/webservices/asp.net/CustEntCls.mspx?mfr=true 发布日期 : ...
- Catalog of Patterns of Enterprise Application Architecture
Catalog of Patterns of Enterprise Application Architecture Last Significant Update: January 2003 A s ...
- SQL-乐观锁,悲观锁之于并发
每次写博客,第一句话都是这样的:程序员很苦逼,除了会写程序,还得会写博客!当然,希望将来的一天,某位老板看到此博客,给你的程序员职工加点薪资吧!因为程序员的世界除了苦逼就是沉默.我眼中的程序员大多都不 ...
- Coarse-Grained lock 粗粒度锁
用一个锁Lock一组相关的对象 有时,需要按组来修改多个对象. 这样,在需要锁住其中一个的时候,必须连带地将其他的对象都上锁. 为每一个对象都加上一个锁是很繁琐的. 粗粒度锁是覆盖多个对象的单个锁. ...
- 观锁与悲观锁(Hibernate)
乐观锁与悲观锁 文章转自网上好像是玉米田的,忘记了 锁( locking ) 业务逻辑的实现过程中,往往需要保证数据访问的排他性.如在金融系统的日终结算 处理中,我们希望针对某个 cut-off 时间 ...
- 不容易理解的 lock 和 merge
Hibernate:不容易理解的 lock 和 merge 目录 背景Lock官方的注释LockMode.NONELockMode.READLockMode.UPGRADEMerge官方注释detac ...
- Java Hibernate中的悲观锁和乐观锁的实现
锁(locking) 业务逻辑的实现过程中,往往需要保证数据访问的排他性.如在金融系统的日终结算 处理中,我们希望针对某个cut-off时间点的数据进行处理,而不希望在结算进行过程中 (可能是几秒种, ...
- SQL Server 锁机制 悲观锁 乐观锁 实测解析
先引入一些概念,直接Copy其他Blogs中的,我就不单独写了. 一.为什么会有锁 多个用户同时对数据库的并发操作时会带来以下数据不一致的问题: 1.丢失更新 A,B两个用户读同一数据并进行修改,其中 ...
随机推荐
- hdu 1429 bfs+二进制状态压缩
开始时候只用了BFS,显然超时啊,必然在结构体里加一个数组什么的判重啊,开始用的一个BOOL数组,显然还是不行,复杂度高,每次都要遍历数组来判重:后百度之,学习了二进制状态压缩,其实就用一个二进制数来 ...
- Java的变量类型
以下内容引用自http://wiki.jikexueyuan.com/project/java/variable-types.html: 一个变量提供了程序可以操作的命名存储.Java中的每个变量都有 ...
- Building clang on RedHat
http://btorpey.github.io/blog/2015/01/02/building-clang/ clang is a great compiler, with a boatload ...
- Python开发的一个IDE推荐,Sublime Text 3
Sublime Text 3 官网下载地址为, LINK. 目前最新版本是3114. 这里转载泱泱长空的授权文件(注册码)文章[1],将几个可以用的注册码列举如下: 补充:2016.05 最近经过测试 ...
- [转]图解eclipse 查看原始类出现The jar file rt.jar has no source attachment
原文:http://blog.csdn.net/u011514810/article/details/53196371 ---------------------------------------- ...
- cocoapods应用第一部分-xcode创建.framework相关
问题的提出: 随着项目的越来越大,可能会出现好几个团队共同维护一个项目的情况,比如:项目组A负责当中的A块,项目组B负责当中的B块.....这几块彼此之间既独立,也相互联系.对于这样的情况,能够採用约 ...
- Highcharts:X轴分组堆叠图
在设计一个项目中的数据展示页面时.想要设计双X轴,一个轴显示须要的项.一个轴对这些项进行分组.效果如图: Highcharts自带双X轴展示方式.可是效果不是太理想.调整起来也会麻烦些 看到Highc ...
- 《鸟哥的Linux私房菜-基础学习篇(第三版)》(六)
第5章 首次登陆与在线求助man page 1. 首次登陆系统 首先谈了首次登陆CentOS 5.x界面.登陆选项中的会话是能够使用不同的图形界面来操作整个Linux系统. ...
- JavaScript-创建第一个自己的类库
通过上一节面向对象和原型的学习. 我们知道了怎样创建一个类,包含类的私有化属性和方法.公有化属性和方法.静态属性和方法.在这里略微回想一下.首先要创建一个类能够通过1.new object().2.利 ...
- Ubuntu16.04 下python2 | python3
在终端分别输入python,python2,python3 python和python2默认都是python2 python3才是python3 Ubuntu下是默认没有pip的,需要自己手动安装 s ...