乐观锁简介
乐观锁是一种并发控制机制,通常用于多个用户或线程并发访问共享资源时,保证数据一致性的一种方法。与悲观锁不同,乐观锁假设在大多数情况下并发冲突不会发生(所以叫乐观),因此不会在访问资源之前进行加锁,而是在更新资源时进行检查。
通俗点就是 我认为这个事务很少会有高并发的冲突,所以我不对资源上锁,只乐观地上个锁看这个事务有没有被其他客户端影响,如果被影响就终止事务或重做
乐观锁的工作本质
在乐观锁中,当一个用户或线程准备更新资源时,会先获取一个版本号或标记(例如,数据的时间戳或哈希值),然后在提交更新之前,再次检查这个标记是否发生了变化。如果在这段时间内资源没有被其他用户或线程修改,则更新操作可以继续进行;但如果资源已经被其他用户或线程修改,更新操作将被中断或回滚。
发生乐观锁异常后的解决办法
乐观锁的优点在于它不需要显式地锁定资源,因此可以提高并发性能和吞吐量。但是,它需要依赖于合适的版本号或标记来判断资源是否被修改,因此在某些情况下可能会导致更新冲突。解决更新冲突的方法通常包括重试更新操作、合并更新内容或使用更复杂的冲突解决策略。