redis事务中的WATCH
来源:互联网 发布:win7本地php环境搭建 编辑:程序博客网 时间:2024/05/17 00:58
在Redis的事务中,WATCH命令可用于提供CAS(check-and-set)功能。假设我们通过WATCH命令在事务执行之前监控了多个Keys,倘若在WATCH之后有任何Key的值发生了变化,EXEC命令执行的事务都将被放弃,同时返回Null multi-bulk应答以通知调用者事务执行失败。例如,我们再次假设Redis中并未提供incr命令来完成键值的原子性递增,如果要实现该功能,我们只能自行编写相应的代码。其伪码如下:
val = GET mykey
val = val + 1
SET mykey $val
以上代码只有在单连接的情况下才可以保证执行结果是正确的,因为如果在同一时刻有多个客户端在同时执行该段代码,那么就会出现多线程程序中经常出现的一种 错误场景--竞态争用(race condition)。比如,客户端A和B都在同一时刻读取了mykey的原有值,假设该值为10,此后两个客户端又均将该值加一后set回Redis服 务器,这样就会导致mykey的结果为11,而不是我们认为的12。为了解决类似的问题,我们需要借助WATCH命令的帮助,见如下代码:
WATCH mykey
val = GET mykey
val = val + 1
MULTI
SET mykey $val
EXEC
和此前代码不同的是,新代码在获取mykey的值之前先通过WATCH命令监控了该键,此后又将set命令包围在事务中,这样就可以有效的保证每个连接在 执行EXEC之前,如果当前连接获取的mykey的值被其它连接的客户端修改,那么当前连接的EXEC命令将执行失败。这样调用者在判断返回值后就可以获 悉val是否被重新设置成功。
WATCH mykey
val = GET mykey
val = val + 1
MULTI
SET mykey $val
EXEC
和此前代码不同的是,新代码在获取mykey的值之前先通过WATCH命令监控了该键,此后又将set命令包围在事务中,这样就可以有效的保证每个连接在 执行EXEC之前,如果当前连接获取的mykey的值被其它连接的客户端修改,那么当前连接的EXEC命令将执行失败。这样调用者在判断返回值后就可以获 悉val是否被重新设置成功。
http://blog.csdn.net/e421083458/article/details/49741451
http://blog.sina.com.cn/s/blog_ae8441630101cgy3.html
0 0
- redis事务中的WATCH
- redis 事务之watch
- redis事务与watch
- redis的事务和watch
- redis的事务和watch
- Redis的事务和watch
- redis的事务和watch
- Spring Redis 事务Multi Exec Watch
- Redis - 事务(multi,exec,watch,unwatch)
- Redis的事务之watch使用
- redis事务中的WATCH命令和基于CAS的乐观锁
- redis事务中的WATCH命令和基于CAS的乐观锁
- redis事务中的WATCH命令和基于CAS的乐观锁
- redis的事务(redis的watch,multi,exec用法)
- redis 事务(MULTI 、 EXEC 、 DISCARD 和 WATCH )
- Redis 事务和watch应用于秒杀商品应用
- Redis 中的事务
- redis中的事务
- Linux环境下,更新代码补丁后,重启服务器常用命令
- Apache Camel框架入门示例
- sgu438
- redis 的两种持久化方式及原理
- Android根据Url显示gif类型图片
- redis事务中的WATCH
- C#里partial关键字的作用(转摘)
- memcached java客户端比较
- centos7下快速安装mysql-yum安装
- Git 仓库的创建和常用命令的使用
- 20、在Java应用中使用Json
- [摘选]memcached全面剖析—— 客户端选择(一致性哈希算法)
- AngularJS中的数据绑定 post
- Should new index columns be in the key, or included?