Redis:事务

基本命令

  • MULTI :开启事务,之后的命令会放入队列,直到 EXECDISCARD 被调用。
  • EXEC:执行事务中的所有命令。
  • DISCARD:取消事务,清空命令队列。
  • WATCH:监视一个或多个键,如果在事务执行前这些键被修改,事务将不会执行。

事务执行流程

  1. 开启事务 :使用 MULTI 命令开启一个事务。在这个阶段,Redis 会标记当前客户端进入事务状态,并准备接收后续的命令。

  2. 命令入队 :在事务开启后,客户端发送的所有命令都会被放入事务队列中,而不会立即执行。每个命令入队后,Redis 会返回 QUEUED 表示命令已成功入队

  3. 执行事务 :使用 EXEC 命令执行事务队列中的所有命令。Redis 会按照命令入队的顺序依次执行这些命令,并将每个命令的执行结果返回给客户端。

  4. 取消事务 :使用 DISCARD 命令取消当前事务,并清空事务队列。在取消事务后,客户端可以重新开始一个新的事务。

    MULTI
    OK
    SET key1 value1
    QUEUED
    SET key2 value2
    QUEUED
    EXEC

    1. OK
    2. OK

WATCH命令

WATCH 用于实现乐观锁,监视一个或多个键,如果在事务执行前这些键被修改,事务将不会执行。

复制代码
> WATCH key1
OK
> MULTI
OK
> SET key1 newvalue
QUEUED
> EXEC
(nil)
  • 如果在 MULTI 之后、EXEC 之前 key1 被修改,事务将执行失败,返回 (nil)
  • 可以通过 UNWATCH 取消监控。

特性

  • 原子性(Atomicity) :Redis 事务可以保证一个事务中的所有命令要么都执行,要么都不执行。但是如果在事务执行过程中发生了运行时错误,Redis 不会回滚事务,而是继续执行后续命令,这与传统数据库的严格原子性有所不同。
  • 一致性(Consistency):Redis 事务可以保证数据的一致性,前提是事务中的命令没有逻辑错误。
  • 隔离性(Isolation):Redis 的事务是单线程执行的,这意味着在一个事务执行期间,不会有其他事务同时执行,从而避免了并发访问导致的数据不一致问题。
  • 持久性(Durability):Redis 事务本身并不直接保证持久性。持久性取决于 Redis 所采用的持久化策略,如 RDB(快照)和 AOF(追加日志)。

应用场景

库存管理:在电商系统中,库存管理是一个重要的问题。使用 Redis 事务可以保证库存扣减操作的原子性,避免超卖问题。

用户积分系统:在用户积分系统中,使用 Redis 事务可以保证积分的增加和减少操作的原子性。

相关推荐
qq_318121596 小时前
互联网大厂Java面试故事:从Spring Boot到微服务架构的技术挑战与解答
java·spring boot·redis·spring cloud·微服务·面试·内容社区
计算机毕设VX:Fegn08957 小时前
计算机毕业设计|基于springboot + vue医院设备管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
Mr__Miss7 小时前
保持redis和数据库一致性(双写一致性)
数据库·redis·spring
Knight_AL8 小时前
Spring 事务传播行为 + 事务失效原因 + 传播行为为什么不用其他模式
数据库·sql·spring
倔强的石头_8 小时前
时序数据时代的“存储与分析困局”解析及金仓解决方案
数据库
计算机毕设VX:Fegn08958 小时前
计算机毕业设计|基于springboot + vue小型房屋租赁系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
倔强的石头_9 小时前
场景化落地指南——金仓时序数据库在关键行业的应用实践
数据库
SelectDB9 小时前
驾驭 CPU 与编译器:Apache Doris 实现极致性能的底层逻辑
运维·数据库·apache
zbguolei9 小时前
MySQL根据身份证号码计算出生日期和年龄
数据库·mysql
马克学长10 小时前
SSM校园图书借阅服务系统jd2z8(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·图书管理系统·ssm 框架·ssm 校园图书借阅系统