从入门到精通【Redis】理解Redis事务

文章目录

    • [📕1. 什么是Redis事务](#📕1. 什么是Redis事务)
    • [📕2. 事务操作](#📕2. 事务操作)
        • [✏️2.1 MULTI](#✏️2.1 MULTI)
        • [✏️2.2 EXEC](#✏️2.2 EXEC)
        • [✏️2.3 DISCARD](#✏️2.3 DISCARD)
        • [✏️2.4 WATCH](#✏️2.4 WATCH)
        • [✏️2.5 UNWATCH](#✏️2.5 UNWATCH)

特此注明 :
Designed By :长安城没有风
Version:1.0
Time:2025.09.30
Location:辽宁 · 大连

📕1. 什么是Redis事务

Redis 的事务和 MySQL 的事务概念上是类似的,都是把⼀系列操作绑定成⼀组,让这⼀组能够批量执⾏。但是 Redis 的事务和 MySQL 的事务有一下几种区别:

  1. 弱化的原⼦性 : redis 没有 "回滚机制",只能 "批量执⾏",不能做到 "⼀个失败就恢复到初始状态"。
  2. 不保证⼀致性 : 不涉及 "约束",也没有回滚,MySQL 的⼀致性体现的是运⾏事务前和运⾏后,结果都是合理有效的,不会出现中间⾮法状态。
  3. 不需要隔离性 : 也没有隔离级别。因为不会并发执⾏事务 (redis 单线程处理请求)。
  4. 不需要持久性 : 是保存在内存的。是否开启持久化,是redis-server ⾃⼰的事情,和事务⽆关。

Redis 事务本质上是在服务器上搞了⼀个 "事务队列",每次客⼾端在事务中进⾏⼀个操作,都会把命令先发给服务器,放到 "事务队列" 中,但是并不会⽴即执⾏,⽽是会在收到 EXEC 命令之后,才真正执⾏队列中的所有操作(Redis 的事务的功能相⽐于 MySQL 来说,是弱化很多的,只能保证事务中的这⼏个操作是 "连续的",不会被别的客户端 "加塞")。

📕2. 事务操作

✏️2.1 MULTI

MULTI:开启⼀个事务,执⾏成功返回 OK。

bash 复制代码
127.0.0.1:6379> MULTI
OK
✏️2.2 EXEC

EXEC:真正执⾏事务。

bash 复制代码
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> set k1 1
QUEUED
127.0.0.1:6379> set k2 2
QUEUED
127.0.0.1:6379> set k3 3
QUEUED
127.0.0.1:6379> EXEC
1) OK
2) OK
3) OK

每次添加⼀个操作,都会提⽰ "QUEUED",说明命令已经进⼊客户端的队列了,真正执⾏ EXEC 的时候,客户端才会真正把上述操作发送给服务器。

✏️2.3 DISCARD

DISCARD:放弃当前事务,此时直接清空事务队列,之前的操作都不会真正执⾏到。

bash 复制代码
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> set k1 1
QUEUED
127.0.0.1:6379> set k2 2
QUEUED
127.0.0.1:6379> DISCARD
OK
✏️2.4 WATCH

WATCH:监控客户端一组具体的key

  1. 当开启事务的时候,如果对 watch 的 key 进⾏修改,就会记录当前 key 的 "版本号"。(版本号是个简单的整数,每次修改都会使版本变⼤,服务器来维护每个 key 的版本号情况)
  2. 在真正提交事务的时候,如果发现当前服务器上的 key 的版本号已经超过了事务开始时的版本号,就会让事务执⾏失败。(事务中的所有操作都不执⾏)
bash 复制代码
客户端1
127.0.0.1:6379> watch k1 # 开始监控 k1
OK
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> set k1 100 # 进⾏修改, 从服务器获取 k1 的版本号是 0. 记录 k1 的版本号. (还没真修改呢, 版本号不变)
QUEUED
127.0.0.1:6379> set k2 1000 
QUEUED

客户端2
127.0.0.1:6379> set k1 200 # 修改成功, 使服务器端的 k1 的版本号 0 -> 1
OK

客户端1
127.0.0.1:6379> EXEC # 真正执⾏修改操作, 此时对⽐版本发现, 客⼾端的 k1 的版本号是 0, 服务器上的版本号是 1, 版本不⼀致! 说明有其他客⼾端在事务中间修改了 k1 !!! 
127.0.0.1:6379> get k1
(nil)
127.0.0.1:6379> get k2
(nil)
# 此时说明事务已经被取消了,这次提交的所有命令都没有执⾏。
✏️2.5 UNWATCH

UNWATCH:取消对 key 的监控,相当于 WATCH 的逆操作。

相关推荐
不剪发的Tony老师14 分钟前
MySQL 9.5创新版发布,有哪些新功能?
数据库·mysql
布朗克1681 小时前
MySQL 及 SQL 注入详细说明
数据库·sql·mysql·1024程序员节
武子康1 小时前
Java-154 深入浅出 MongoDB 用Java访问 MongoDB 数据库 从环境搭建到CRUD完整示例
java·数据库·分布式·sql·mongodb·性能优化·nosql
Austindatabases2 小时前
DBA 从“修电脑的” 到 上演一套 “数据治理” 大戏 --- 维护DBA生存空间,体现个体价值
数据库·dba
LB21122 小时前
Redis黑马点评 day01
数据库·redis·缓存
白小筠2 小时前
创建Django项目
数据库·django·sqlite
扑克中的黑桃A4 小时前
金仓多模数据库平替MongoDB的电子证照国产化实践——从2TB数据迁移到1600+并发支撑
数据库
计算机毕业设计小帅4 小时前
【2026计算机毕业设计】基于Django的社区婴幼儿预防接种系统
数据库·django·课程设计
友友马4 小时前
『 数据库 』MySQL复习 - 内置函数详解
数据库·mysql
互联网中的一颗神经元5 小时前
小白python入门 - 6. Python 分支结构——逻辑决策的核心机制
开发语言·数据库·python