Redis乐观锁演示

Redis乐观锁演示,第1张

Redis乐观锁演示 Redis乐观锁演示

执行MULTI之前,先执行WATCH key1 key2 … keyn,以此可以监听一个或多个key,如果在事务之前这些个key被其他命令所改动,那么该事务将被打断。其实就是给这些key上了乐观锁。

注意:WATCH并不是对某个key使用一次就终生使用的,他的有效期只有在使用WATCH后执行的第一个事务中生效。在该事务执行了EXEC或者DISCARD后,WATCH就消失了。
很拗口的话,简单说怎么用吧,就是每次执行事务前,如果我们需要给某个key或者某些key上乐观锁,那么我们就要WATCH这些个key。切记,是每次!每次!每次!

下面我们实际来演示一下效果:

首先,我们使用XShell连接同一个服务器,并打开Redis客户端

然后我们设置balance的值为100。并让两个客户端监听我们的balance(watch balance)。
第一个客户端执行命令:

第二个客户端执行命令:

此时我们让两个客户端同时开启事务,并在在第一个客户端中,让balance+100,在第二个客户端中让balance + 200。

然后先让第一个客户端执行,再让第二个客户端执行。


此时,balance的值为200,而且,我们从上面的截图可以看到,加200的 *** 作返回了一个nil。也就是该 *** 作其实没有执行。

当然了,如果要取消乐观锁的话,那么我们可以使用UNWATCH命令。如果在执行WATCH命令之后,EXEC命令或DISCARD命令先被执行了的话,那么就不需要再执行UNWATCH了。

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

原文地址:https://54852.com/zaji/5605552.html

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

发表评论

登录后才能评论

评论列表(0条)

    保存