zoukankan      html  css  js  c++  java
  • Redis事务

    概述

    Redis中的事务是一组命令的队列,事务中的命令要么都执行,要么都不执行。相比于MySQL的事务来说,Redis对事务的支持还是比较简单的。

    Redis和MySQL的事务对比

    Redis MySQL
    开启 multi start transaction
    语句 普通命令 普通SQL语句
    失败 discard rollback
    成功 exec commit

    简单入门

    Redis的事务可以理解为将多条命令放入一个队列中,再将队列发送给Redis,让Redis按顺序执行队列中命令。

    在使用Redis的时候可能会出现两种错误(1)语法错误(2)运行错误,那么Redis会如何处理呢?

    (1)语法错误

    (2)运行错误

    可以看出开启事务后,Redis只会对入队列的命令做语法检查,如果命令存在语法错误则事务自动DISCARD。当EXEC后,Redis会依次执行队列中的命令,如果有错误,依旧会执行后面的命令。可以看出Redis的事务并不支持回滚,要想避免运行错误,只能靠开发者在编写代码的时候能认真点。

    WATCH

    在实际的应用中,可能会存在竞态的情况,如多个用户抢一张车票。这时候可以使用WATCH命令来解决这个问题

    Redis客户端1

    Redis客户端2

    Redis客户端1

    可以看到客户端1在执行EXEC之前,客户端2先对count进行了-1,count的值变成了0,当客户端1执行了EXEC之后,count的值应该变成-1才对。但是count的值依旧是0,原因是WATCH命令监听了count,当执行事务的时候,发现count的值已经被修改,所以事务中操作count的命令无效,返回nil。

  • 相关阅读:
    Arrays类
    spring boot 整合ehcache
    自定义注解
    图像技术经典会议
    机器学习常见优化器
    TensorFlow学习笔记(一)
    Linux 下 jupyter安装
    学生、课程、分数关系的设计与实现 Hibernate
    Hibernate连接三种数据库的配置(SQL Server、Oracle、MySQL)
    Oracle11g服务详细介绍及哪些服务是必须开启的?
  • 原文地址:https://www.cnblogs.com/helbing/p/5248312.html
Copyright © 2011-2022 走看看