从入门到精通【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 的逆操作。

相关推荐
全栈老石2 小时前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
曲幽4 小时前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
倔强的石头_21 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou642 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
李广坤3 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区4 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1774 天前
《从零搭建NestJS项目》
数据库·typescript
加号35 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏5 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐5 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端