zoukankan      html  css  js  c++  java
  • Redis事务使用方法

    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

  • 相关阅读:
    leecode 240. 搜索二维矩阵 II
    leecode 103. 二叉树的锯齿形层序遍历
    leecode 362. 敲击计数器
    leecode 152. 乘积最大子数组
    leecode 560. 和为K的子数组
    面试题 08.12. 八皇后
    leecode 450. 删除二叉搜索树中的节点
    leecode 384. 打乱数组
    leecoode 138. 复制带随机指针的链表
    mysql基本指令2
  • 原文地址:https://www.cnblogs.com/chengxuzhixin/p/6398832.html
Copyright © 2011-2022 走看看