美文网首页
乐观锁与悲观锁区别和总结

乐观锁与悲观锁区别和总结

作者: 六月星空2011 | 来源:发表于2017-11-29 09:36 被阅读0次

1.乐观锁介绍

  • 乐观锁(Optimistic Locking) 相对悲观锁而言,乐观锁假设认为数据一般情况下不会造成冲突,所以在数据进行提交更新的时候,才会正式对数据的冲突与否进行检测,如果发现冲突了,则让返回用户错误的信息,让用户决定如何去做。
1.1 乐观锁的实现方式
  1. 使用数据版本(Version)记录机制实现,这是乐观锁最常用的一种实现方式。
    何谓数据版本? 即为数据增加一个版本标识,一般是通过为数据库表增加一个数字类型的 “version” 字段来实现。当读取数据时,将version字段的值一同读出,数据每更新一次,对此version值加一。当我们提交更新的时候,判断数据库表对应记录的当前版本信息与第一次取出来的version值进行比对,如果数据库表当前版本号与第一次取出来的version值相等,则予以更新,否则认为是过期数据。
    图例说明
    如上图所示,如果更新操作顺序执行,则数据的版本(version)依次递增,不会产生冲突。但是如果发生有不同的业务操作对同一版本的数据进行修改,那么,先提交的操作(图中B)会把数据version更新为2,当A在B之后提交更新时发现数据的version已经被修改了,那么A的更新操作会失败。
    示例代码:
    update t_goods
    set status=2,version=version+1
    where id=#{id} and version=#{version};
  1. 乐观锁定的第二种实现方式和第一种差不多,同样是在需要乐观锁控制的table中增加一个字段,名称无所谓,字段类型使用时间戳(timestamp)[时间戳类型: 行数据更新时, 时间会自动更新], 和上面的version类似,也是在更新提交的时候检查当前数据库中数据的时间戳和自己更新前取到的时间戳进行对比,如果一致则OK,否则就是版本冲突。
  • 乐观锁的实现
    1.CAS(Compare And Swap)
    2.MVCC(Multi-Version Concurrency Control)
  • 乐观锁特点
    1. 并发度高
    2. 程序实现,不会存在死锁

2. 悲观锁介绍

  • 悲观锁,正如其名,具有强烈的独占排他特性。它指的是对数据被外界(包括本系统当前的其他事务,以及来自外部系统的事务处理)修改持保守态度,因此,在整个数据处理过程中,将数据处于锁定状态悲观锁的实现,往往依靠数据库提供的锁机制(也只有数据库层提供的锁机制才能真正保证数据访问的排他性,否则,即使在本系统中实现了加锁机制,也无法保证外部系统不会修改数据)。
  • 以MySQL 的InnoDB 为例,预设的Tansaction isolation level 为REPEATABLE READ.[要使用悲观锁,我们必须关闭mysql数据库的自动提交属性, set autocommit=0]
  • SELECT 的读取锁的两种方式:
    1. SELECT ... LOCK IN SHARE MODE
    2. SELECT ... FOR UPDATE
    两种方式在事务(Transaction) 进行当中SELECT 到同一个数据表时,都必须等待其它事务数据被提交(Commit)后才会执行。而主要的不同在于LOCK IN SHARE MODE 在有一方事务要Update 同一个表单时很容易造成死锁
    简单的说,如果SELECT 后面若要UPDATE 同一个表单,最好使用SELECT ... UPDATE。
  • MySQL SELECT ... FOR UPDATE 的Row Lock(行锁)Table Lock(表锁).
    由于InnoDB 预设是Row-Level Lock,所以只有「明确」的指定主键,MySQL 才会执行Row lock (只锁住被选取的数据) ,否则MySQL 将会执行Table Lock (将整个数据表单给锁住).
    1.明确指定主键,并且有此数据,row lock
    2.明确指定主键,若查无此数据,无lock
    3.无主键 /主键不明确,table lock
  • 除了主键外,使用索引也会影响数据库的锁定级别
    1.明确指定索引,并且有此数据,row lock
    2.明确指定索引,若查无此数据,无lock
  • 悲观锁特点
    1.并发度小
    2.依靠数据实现

参考博客:

相关文章

  • 乐观锁和悲观锁

    参考来源 深入理解乐观锁与悲观锁 乐观锁的一种实现方式——CAS mysql乐观锁总结和实践 乐观锁和悲观锁 悲观...

  • 蚂蚁面试

    1、mysql乐观锁和悲观锁的区别? 乐观锁通过MVCC,版本实现,悲观锁select... for update...

  • Mysql锁

    按照使用方式,锁分为: 悲观锁 乐观锁 乐观锁 概念就不细讲了,乐观锁和悲观锁的区别是乐观锁是假设在修改数据之前,...

  • java中的乐观锁和悲观锁的区别?

    java中的乐观锁和悲观锁的区别?

  • 锁的概述

    乐观锁与悲观锁 悲观锁 乐观锁和悲观锁的概念出自数据库,但在java并发包中也引入和类似的概念(乐观锁/悲观锁是一...

  • 并发参数

    悲观锁与乐观锁 悲观锁 synchronized和ReentrantLock等独占锁就是悲观锁思想的实现乐观锁一般...

  • 乐观锁与悲观锁区别和总结

    1.乐观锁介绍 乐观锁(Optimistic Locking) 相对悲观锁而言,乐观锁假设认为数据一般情况下不会造...

  • CAS 与原子操作

    乐观锁与悲观锁 锁可以从不同的角度分类。其中,乐观锁和悲观锁是一种分类方式。 乐观锁:乐观锁又称为“无锁”。乐观锁...

  • 看完你就知道的乐观锁和悲观锁

    看完你就知道的乐观锁和悲观锁 Java 锁之乐观锁和悲观锁 [TOC] Java 按照锁的实现分为乐观锁和悲观锁,...

  • 史上最全 Java 中各种锁的介绍

    锁的分类介绍 乐观锁与悲观锁 锁的一种宏观分类是乐观锁与悲观锁。乐观锁与悲观锁并不是特定的指哪个锁(Java 中也...

网友评论

      本文标题:乐观锁与悲观锁区别和总结

      本文链接:https://www.haomeiwen.com/subject/hotubxtx.html