栏目分类:
子分类:
返回
终身学习网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
终身学习网 > IT > 前沿技术 > 大数据 > 大数据系统

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了。

转载请注明:文章转载自 www.051e.com
本文地址:http://www.051e.com/it/600746.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 ©2023-2025 051e.com

ICP备案号:京ICP备12030808号