
在执行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了。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)