每次只允许一个业务事务来访问数据,以防止并发业务事务中的冲突.

  • 离线并发处理通常会出现多个业务事务操作同一数据.
  • 最简单的办法是为整个业务事务保持一个系统事务.但是事务系统不适合于处理长事务.
  • 首选乐观离线锁.
  • 而悲观离线锁,作为它的补充.从一开始就避免冲突.
    • 它要求业务事务在对数据进行操作前就必须获取该数据的锁.
    • 一旦开始了一个业务事务,就确信不会再提交时由于并发冲突而被迫回滚数据.
  • 运行机制
  • 决定使用哪种锁

    • exclusive write lock独占写锁.写目的的会话数据时使用,当对数据的读取要求不高时.
    • exclusive read lock独占读锁.仅是为了读目的时的数据.限制了并发性.
    • read/write lock读/写锁.
      • 读锁和写锁互斥,同一数据记录上只能被附加上一种.
      • 允许并发的读锁.读锁会防止其他业务事务修改数据.但是允许其他业务事务读取记录.
      • 允许同时读增加了系统的并发性.但是其实现复杂.
  • 构建锁管理对象
    • 该对象负责授予或者拒绝业务事务获取/释放锁的请求.
    • 必须知晓被锁住的资源,和锁的拥有者(业务事务).
    • 只能有一张关于锁的表.该表存在于内存或者SQL语句实现的.
    • 锁必须是管理对象的私有域.业务事务只能与管理对象交互,而不能直接操作锁对象.
  • 定义业务事务使用锁管理对象的协议
    • 对什么加锁,

      • 通常仅在ID或主键加锁,因为使用它们来查找对象.
    • 何时加锁,
      • 通常在读取数据之前获取锁.保证加锁的是最新数据时采取加锁.
    • 何时释放锁,
      • 在业务事务完成时释放.
    • 当无法获得锁时的动作.
      • 可能会在业务事务一开始就因为无法获取锁而终止事务.
    • 对于相互等待对象的锁资源造成的死锁.
      • 让锁管理对象在锁不可用时抛出异常即可.直接避免死锁.
    • 丢失的会话中锁的超时.Client端在事务进行中崩溃了.
      • 让应用服务器的超时机制处理.
      • 给每个锁加上时间戳,定时清除超过一定时间的锁.
  • 使用时机
  • 适合于冲突率很高的并发会话中.
  • 也用于冲突处理代价很高时.
  • 它只能作为乐观锁的补充,不推荐使用.
  • 可以考虑使用长事务.其实现比悲观锁简单.

Pessimistic Offline Lock悲观离线锁的更多相关文章

  1. Optimistic Offline Lock乐观离线锁

    通过冲突检测和(发生冲突时的)事务回滚,来防止并发业务事务中的冲突. 通常一个业务事务的执行,会跨越一系列的系统事务. 一旦超出了单个系统事务的范围,就不能仅依靠DB管理程序来保证数据一致性. 乐观离 ...

  2. [转]掌握 ASP.NET 之路:自定义实体类简介 --自定义实体类和DataSet的比较

    转自: http://www.microsoft.com/china/msdn/library/webservices/asp.net/CustEntCls.mspx?mfr=true 发布日期 : ...

  3. Catalog of Patterns of Enterprise Application Architecture

    Catalog of Patterns of Enterprise Application Architecture Last Significant Update: January 2003 A s ...

  4. SQL-乐观锁,悲观锁之于并发

    每次写博客,第一句话都是这样的:程序员很苦逼,除了会写程序,还得会写博客!当然,希望将来的一天,某位老板看到此博客,给你的程序员职工加点薪资吧!因为程序员的世界除了苦逼就是沉默.我眼中的程序员大多都不 ...

  5. Coarse-Grained lock 粗粒度锁

    用一个锁Lock一组相关的对象 有时,需要按组来修改多个对象. 这样,在需要锁住其中一个的时候,必须连带地将其他的对象都上锁. 为每一个对象都加上一个锁是很繁琐的. 粗粒度锁是覆盖多个对象的单个锁. ...

  6. 观锁与悲观锁(Hibernate)

    乐观锁与悲观锁 文章转自网上好像是玉米田的,忘记了 锁( locking ) 业务逻辑的实现过程中,往往需要保证数据访问的排他性.如在金融系统的日终结算 处理中,我们希望针对某个 cut-off 时间 ...

  7. 不容易理解的 lock 和 merge

    Hibernate:不容易理解的 lock 和 merge 目录 背景Lock官方的注释LockMode.NONELockMode.READLockMode.UPGRADEMerge官方注释detac ...

  8. Java Hibernate中的悲观锁和乐观锁的实现

    锁(locking) 业务逻辑的实现过程中,往往需要保证数据访问的排他性.如在金融系统的日终结算 处理中,我们希望针对某个cut-off时间点的数据进行处理,而不希望在结算进行过程中 (可能是几秒种, ...

  9. SQL Server 锁机制 悲观锁 乐观锁 实测解析

    先引入一些概念,直接Copy其他Blogs中的,我就不单独写了. 一.为什么会有锁 多个用户同时对数据库的并发操作时会带来以下数据不一致的问题: 1.丢失更新 A,B两个用户读同一数据并进行修改,其中 ...

随机推荐

  1. hdu 1501 基本搜索深搜

    #include<stdio.h> #include<string.h> char s1[300],s2[300],s[500]; int len1,len2,len3,fla ...

  2. django学习之- modelForm

    ModelForm(耦合很强) 可以实现 1:数据库操作 2:数据验证 使用地方:1:小型项目,2:自定制jdango admin 功能: 1:可以生成html标签:class Meta... 2:m ...

  3. hdu 3237

    dp 状态压缩 #include <cstdio> #include <cstdlib> #include <cmath> #include <map> ...

  4. POJ 3230 【DP】

    题意: 某货旅行,在n个城市呆m天. 给出从第i个城市到第j个城市的路费,或者留在某个城市的生活费. 给出在第i天在第j个城市的收益. 可以在城市之间任意穿梭逗留没有其他特殊要求. 求收益最大是多少. ...

  5. Deepin-安装vscode

    安装方式有两种: 1.通过命令安装 sudo apt-get install vscode 2.通过deb或rpm包安装 我们是Debian系列的系统,所以用deb包,关于红帽系统,请使用rpm包. ...

  6. Scrum 常见错误实践 之 形式化的站会

    站会作为一个团队最容易实施的敏捷实践,为广大team leader和老板们所喜欢,但大部分程序员却很抵触.其主要原因就是很多时候站会都流于形式,没能帮助团队成员解决问题.改进效率. 一种常见的情况就是 ...

  7. MongoDB使用入门

    1.MongoDB的安装 步骤一:下载MongoDB 下载安装包:http://fastdl.mongodb.org/linux/mongodb-linux-i686-2.0.4.tgz 步骤二:设置 ...

  8. Linux登录自动切换root账户与历史命令优化

    1:当我们Linux系统优化完成,会使用oldboy用户远程连接CRT登录,每次连接都需要使用sudo su - 或者su - 输入密码登录,请问如何在CRT连接的时候自动的切换到root账户,(提示 ...

  9. 云上领跑,快人一步:华为云抢先发布Redis5.0

    12月17日,华为云在DCS2.0的基础上,快人一步,抢先推出了新的Redis 5.0产品,这是一个崭新的突破.目前国内在缓存领域的发展普遍停留在Redis4.0阶段,华为云率先发布了Redis5.0 ...

  10. 李洪强iOS开发之RunLoop的原理和核心机制

    李洪强iOS开发之RunLoop的原理和核心机制 搞iOS之后一直没有深入研究过RunLoop,非常的惭愧.刚好前一阵子负责性能优化项目,需要利用RunLoop做性能优化和性能检测,趁着这个机会深入研 ...