redis watch事务与乐观锁

本文介绍了Redis中的Watch命令如何实现乐观锁,通过监控键值对确保事务在执行时数据未被篡改。在事务开启前,使用Watch监控特定键,如果在事务执行前键的值发生变化,事务将回滚。这种机制在高并发环境中类似CAS操作,能有效防止数据冲突。同时,文章提供了一个使用Watch进行事务回滚的案例,强调在发现事务执行失败时需取消监视并重新监视以确保数据一致性。
摘要由CSDN通过智能技术生成

概述

监控(Watch)

  悲观锁:

    什么时候都会出问题,无论做什么都加锁

  乐观锁:

    认为什么时候都不会出现问题,所以不会上锁!更新数据的时候去判断一下,再此期间是否有人修改过这个数据

    mysql获取version

    更新的时候比较version

在 Redis 中使用 watch 命令可以决定事务是        执行     还是       回滚。

一般而言,可以在 multi 命令之前使用 watch 命令监控某些键值对,然后使用 multi 命令开启事务,执行各类对数据结构进行操作的命令,这个时候这些命令就会进入队列。

当 Redis 使用 exec 命令执行事务的时候,它首先会去比对被 watch 命令所监控的键值对,

如果没有发生变化,那么它会执行事务队列中的命令,提交事务;
如果发生变化,那么它不会执行任何事务中的命令,而去事务回滚。
无论事务是否回滚 , Redis 都会去取消执行事务前的 watch 命令

 

Redis 参考了多线程中使用的 CAS (比较与交换, Compare And Swap ) 去执行的。在

数据高并发环境的操作中,我们把这样的一个机制称为乐观锁.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

念衢

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值