• 如何利用Redis进行事务处理呢?


    一、概述

    事务的本质,其实就是一组命令的集合。一个事务中的所有命令都会按照命令的顺序去执行,而中间不会被其他命令加塞

    Redis提供了事务相关的5个指令,分别是:DISCARDEXECMULTIUNWATCHWATCH。如下图所示:

    下面我们就对Redis的事务操作一一的进行介绍。

    二、MULTI(v1.2.0)

    指令格式MULTI

    操作逻辑:标记一个事务块的开始。随后的指令将在执行EXEC时作为一个原子执行。简而言之,我们可以使用MULTI来开启一个事务

    操作演示

    操作解释: 我们发现,在事务中每次执行一条指令,就会返回QUEUED,表明指令已经存入了这个事务的执行队列中了。但是需要注意的一点是,只是放入了事务队列,但并没有去执行。那什么时候会执行呢?那就来看一下下个指令EXEC。

    三、EXEC(v1.2.0)

    指令格式EXEC

    操作逻辑:执行事务中所有在排队等待的指令并将链接状态恢复到正常。当使用WATCH时,只有当被监视的键没有被修改,且允许检查设定机制时,EXEC会被执行。简而言之,我们可以使用EXEC来提交一个事务

    操作演示

    操作解释: 调用完EXEC之后,正确执行的都会返回OK,并且当我们再次查询account里面的金额的时候,也正确的返回了1100。这就说明,一个事务内的指令是按照顺序执行的。

    四、DISCARD(v2.2.0)

    指令格式DISCARD

    操作逻辑:刷新一个事务中所有在排队等待的指令,并且将连接状态恢复到正常。如果已使用WATCH,DISCARD将释放所有被WATCH的key

    操作演示

    五、WATCH(v2.2.0)

    指令格式WATCH

    操作逻辑:标记所有指定的key被监视起来,在事务中有条件的执行。可以利用WATCH实现Redis的乐观锁

    操作演示1

    操作演示2

    操作解释:当执行了EXEC指令之后,watch就被隐式的执行了unwatch。如果需要再次监控,就需要再次调用WATCH指令。

    六、UNWATCH(v2.2.0)

    指令格式UNWATCH

    操作逻辑:刷新一个事务中已被监视的所有key。如果执行EXEC或者DISCARD,则不需要手动执行UNWATCH 操作演示:(略)

    七、事务中异常的处理

    7.1> 命令语法错误

    针对语法错误,会导致整个事务执行被中断

    操作演示

    7.2> 运行操作错误

    针对执行中的异常,只会导致该条指令的执行失败,而不会影响事务中其他的指令

    操作演示

    今天的文章内容就这些了:

    写作不易,笔者几个小时甚至数天完成的一篇文章,只愿换来您几秒钟的 点赞 & 分享 。

    更多技术干货,欢迎大家关注公众号“爪哇缪斯” ~ \(^o^)/ ~ 「干货分享,每天更新」

  • 相关阅读:
    Java学习之包访问修饰符
    卷积网络识别乳腺癌
    数据安全出境系列——不合规数据的阻断能力
    自动化测试数据生成:Asp.Net Core单元测试利器AutoFixture详解
    JVM分析指令解析-jps/jinfo/jstat/jstack/jmap
    JavaScript简介
    C和C++的区别(4) C++支持函数重载
    yum install ansible无法直接安装Ansible的解决方法
    印度网络安全:威胁与应对
    学术随笔(三):关于做出一个好工作的流程中期总结
  • 原文地址:https://blog.csdn.net/qq_26470817/article/details/126422347