博客
关于我
Redis乐观锁
阅读量:787 次
发布时间:2019-03-24

本文共 783 字,大约阅读时间需要 2 分钟。

悲观锁与乐观锁的 عشر五 Eval

悲观锁和乐观锁是数据库事务管理中的两种常见机制,它们在不同的场景下发挥着不同的作用。悲观锁(Pessimistic Lock)由于其内置的阻止其他并发事务的机制,给事务带来了严格的上锁保护。无论何时都要加锁,而乐观锁(Optimistic Lock)则采用了刚性版本控制的机制,只在数据对应行进行操作时才上锁,而在更新过程中进行版本比较。

这一技术设计背后的道理是基于对事务特性进行深度理解。在一些传统的高并发场景下,默认的悲观锁机制往往会因为其他意外的并发操作而导致事务提交失败。这种做法虽然能保证事务的完整性,但也会显著增加系统的等待时间和资源消耗。而乐观锁通过版本控制机制,假设大多数情况下没有同时修改同一数据行,从而减少了不必要的排他锁。

以金额表的操作为例,当我们要对某一金额进行初始修改时,数据库系统会生成一个特定的版本号。只要在对应的数据行或相关数据行进行修改时,都必须进行版本号的比较。如果其他事务已经修改了相关数据,当前操作会自动检测到并抛出事务失效的异常,从而避免了数据不一致的问题。

再以一个事务操作为例,假设开发人员在未提交前就进行了其他操作,这种情况在悲观锁机制下会很快被发现,并阻止新的操作。不过在乐观锁的情况下,可以通过版本号的比较机制发现事务失效的情况,从而只提交成功的修改。

这种机制的核心优势在于,乐观锁假设大多数事务不会出现意外情况,当出现冲突时系统能够自动检测并定位问题源,将影响尽量局限。通过合理设置版本控制策略,可以进一步优化事务失效的处理流程,在不影响数据一致性的前提下,最大限度降低事务处理的恢复时间。

在实际应用中,选择使用哪种锁机制需要根据具体的业务场景来综合考量。对于对顺序性和准确性要求极高的场景,悲观锁可能更适合;而对并发幅度较低的场景,乐观锁则能提供更高效的处理体验。

转载地址:http://zzhkk.baihongyu.com/

你可能感兴趣的文章
mysql 记录的增删改查
查看>>
MySQL 设置数据库的隔离级别
查看>>
MySQL 证明为什么用limit时,offset很大会影响性能
查看>>
Mysql 语句操作索引SQL语句
查看>>
MySQL 误操作后数据恢复(update,delete忘加where条件)
查看>>
MySQL 调优/优化的 101 个建议!
查看>>
mysql 转义字符用法_MySql 转义字符的使用说明
查看>>
mysql 输入密码秒退
查看>>
mysql 递归查找父节点_MySQL递归查询树状表的子节点、父节点具体实现
查看>>
mysql 里对root及普通用户赋权及更改密码的一些命令
查看>>
Mysql 重置自增列的开始序号
查看>>
MySQL 错误
查看>>
MySQL 面试,必须掌握的 8 大核心点
查看>>
MySQL 高可用性之keepalived+mysql双主
查看>>
MySql-2019-4-21-复习
查看>>
mysql-connector-java各种版本下载地址
查看>>
mysql-group_concat
查看>>
MySQL-redo日志
查看>>
MySQL-【1】配置
查看>>
MySQL-【4】基本操作
查看>>