MySQL悲观锁和乐观锁的区别是什么

MySQL悲观锁和乐观锁的区别是什么,第1张

MySQL悲观锁和乐观锁的区别是什么

MySQL悲观锁和乐观锁的区别是什么

区别如下:

1、概念不同

乐观锁( Optimistic Locking):

顾名思义,对加锁持有一种乐观的态度,即先进行业务 *** 作,不到最后一步不进行加锁,"乐观"的认为加锁一定会成功的,在最后一步更新数据的时候再进行加锁。

悲观锁(Pessimistic Lock):

正如其名字一样,悲观锁对数据加锁持有一种悲观的态度。因此,在整个数据处理过程中,将数据处于锁定状态。悲观锁的实现,往往依靠数据库提供的锁机制(也只有数据库层提供的锁机制才能真正保证数据访问的排他性,否则,即使在本系统中实现了加锁机制,也无法保证外部系统不会修改数据)。

推荐:MySQL教程

2、实现方式不同

乐观锁:

version方式:一般是在数据表中加上一个数据版本号version字段,表示数据被修改的次数,当数据被修改时,version值会加一。当线程A要更新数据值时,在读取数据的同时也会读取version值,在提交更新时,若刚才读取到的version值为当前数据库中的version值相等时才更新,否则重试更新 *** 作,直到更新成功。

悲观锁:

是由数据库自己实现的,要用的时候,我们直接调用数据库的相关语句就可以了(原理:共享资源每次只给一个线程使用,其它线程阻塞,用完后再把资源转让给其它线程),如行锁、读锁和写锁等,都是在 *** 作之前加锁,在Java中,synchronized的思想也是悲观锁。

3、使用场景不同

乐观锁:

比较适合读取 *** 作比较频繁的场景,如果出现大量的写入 *** 作,数据发生冲突的可能性就会增大,为了保证数据的一致性,应用层需要不断的重新获取数据,这样会增加大量的查询 *** 作,降低了系统的吞吐量。

悲观锁:

比较适合写入 *** 作比较频繁的场景,如果出现大量的读取 *** 作,每次读取的时候都会进行加锁,这样会增加大量的锁的开销,降低了系统的吞吐量。

4、特点不同

乐观锁:

乐观锁的特点先进行业务 *** 作,不到万不得已不去拿锁。即“乐观”的认为拿锁多半是会成功的,因此在进行完业务 *** 作需要实际更新数据的最后一步再去拿一下锁就好。

悲观锁:

悲观锁的特点是先获取锁,再进行业务 *** 作,即“悲观”的认为获取锁是非常有可能失败的,因此要先确保获取锁成功再进行业务 *** 作。通常所说的“一锁二查三更新”即指的是使用悲观锁。

更多技术请关注Python视频教程。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/3016242.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-09-28
下一篇 2022-09-28

发表评论

登录后才能评论

评论列表(0条)

保存