您的位置:首页 > 数据库 > Redis

Redis事务使用方法

2017-02-14 18:08 387 查看


Redis事务

Redis事务是一组命令的集合,也是Redis的最小执行单位之一。一个事务的所有命令,要么都执行,要么都不执行。Redis能保证事务执行期间不会有其他命令插入。

 


相关命令

命令格式说明
DISCARDDISCARD取消事务
EXECEXEC执行事务中的命令
MULTIMULTI标记一个事务的开始
UNWATCHUNWATCH取消对key的监视
WATCHWATCH key [key ...]监视一个或多个key
 

执行MULTI后,在EXEC或DISCARD之前发送的所有命令都会被Redis按顺序缓存起来,并返回QUEUED。执行EXEC后,Redis取出缓存的命令开始执行,并返回每一条命令的返回值。

使用WATCH监控的key如果发生了变化,事务将被打断。在EXEC或DISCARD执行后,WATCH监控自动失效,否则使用UNWATCH取消监控。

注意:

①执行MULTI后不能再执行WATCH,否则返回错误“WATCH inside MULTI is not allowed”;

②如果命令有语法错误Redis会报错,但是运行时出现的错误会被Redis忽略不影响后面的执行,需要自己确保不出现运行时错误;

 


使用方法

1、事务正常执行

192.168.1.100:6379> multi  

OK  

192.168.1.100:6379> set testkey 1  

QUEUED  

192.168.1.100:6379> incr testkey  

QUEUED  

192.168.1.100:6379> get testkey  

QUEUED  

192.168.1.100:6379> exec  

1) OK  

2) (integer) 2  

3) "2"  

 

2、WATCH监控的key变化,事务被打断

192.168.1.100:6379> watch testkey  

OK  

192.168.1.100:6379> multi  

OK  

192.168.1.100:6379> set testkey 1  

QUEUED  

# 此时另一个客户端执行 set testkey 2 改变了testkey的值  

192.168.1.100:6379> exec  

(nil)  

 

原文地址:http://caiguoqing.org/post/111
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  Redis