加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

Redis事务使用方法

发布时间:2020-12-16 04:35:55 所属栏目:安全 来源:网络整理
导读:Redis事务 Redis事务是一组命令的集合,也是Redis的最小执行单位之一。一个事务的所有命令,要么都执行,要么都不执行。Redis能保证事务执行期间不会有其他命令插入。 ? 相关命令 命令 格式 说明 DISCARD DISCARD 取消事务 EXEC EXEC 执行事务中的命令 MULTI

Redis事务

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

?

相关命令

命令 格式 说明
DISCARD DISCARD 取消事务
EXEC EXEC 执行事务中的命令
MULTI MULTI 标记一个事务的开始
UNWATCH UNWATCH 取消对key的监视
WATCH WATCH 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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读