redis之事务

什么是事务

Redis 的事务和 MySQL 的事务概念上是类似的. 都是把一系列操作绑定成一组. 让这一组能够批量执 行. 但是注意体会 Redis 的事务和 MySQL 事务的区别:

但是注意体会 Redis 的事务和 MySQL 事务的区别:

• 弱化的原子性: redis 没有 "回滚机制" . **只能做到这些操作 "批量执行".**不能做到 "一个失败就恢复到 初始状态".也就是说redis的原子性不确保执行是否成功,没有回滚机制,不能回滚

• 不保证一致性: 不涉及 "约束". 也没有回滚. MySQL 的一致性体现的是运行事务前和运行后 , 结果都 是合理有效的, 不会出现中间非法状态.

• 不需要隔离性: 也没有隔离级别, 因为不会并发执行事务 (redis 单线程处理请求) .

• 不需要持久性: 是保存在内存的. 是否开启持久化, 是redis-server 自己的事情, 和事务无关.

Redis 事务本质上是在服务器上搞了一个 "事务队列". 每次客户端在事务中进行一个操作, 都会把命令先 发给服务器, 放到 "事务队列" 中(但是并不会立即执行) 而是会在真正收到 EXEC 命令之后, 才真正执行队列中的所有操作.

事务操作

MULTI 开启一个事务,执行成功返回ok

执行multi后,并没有真正执行,可以看到返回结果时queued,此时只是讲这多个请求保存在了服务器的事务队列中,此时另开一个窗口可以看见,是无法查询到key对应的值的。

EXEC 真正执行事务

当执行exec后,服务器才真正执行了事务队列里的请求,此时才能查询到对应的数据

DISCARD 放弃当前事务.

此时直接清空事务队列. 之前的操作都不会真正执行到

WATCH

watch监控某个key是否在事务执行之前发生了改变

在执行事务的时候,如果某个事务中修改的值被别的客户端修改了,此时就容易出现数据不一致的问 题.

在上述场景中,就可以使用watch来解决该问题

WATCH key → 先监视一个或多个键

MULTI → 开启事务块

SET key 111 → 在事务块中执行命令

EXEC → 执行事务(如果被监视的 key 未被修改,则事务成功执行)

如图,watch key后,另一客户端修改key之后,再执行exec会发现返回nil,随后get key得到的值为被修改后的值222

unwatch 取消监控

WATCH key1 key2

MULTI

... 一些命令 ...

DISCARD # 取消事务,但不会自动取消 WATCH

UNWATCH # 如果需要,手动取消监视

redis 的watch就相当于基于版本号这样的机制来实现的"乐观锁"

总结:

相关推荐
海南java第二人1 小时前
ClickHouse 稀疏索引深度解析:为什么 OLAP 数据库不用 B-Tree?
数据库·clickhouse
Litluecat1 小时前
信创迁移:Oracle切换海量数据库,慢sql扫描
数据库·sql·oracle·信创·海量
消失在人海中1 小时前
Oracle的CURRENT REDO丢失,数据丢失风险分析
数据库·oracle
喵了几个咪2 小时前
选择第三方IAM还是自建权限体系?中小型后台系统权限架构决策指南
数据库·oracle·架构
Elastic 中国社区官方博客3 小时前
Kibana:使用 AI Chat 及 MCP 轻松创建 AI 原生仪表板
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·信息可视化
杨云龙UP3 小时前
Oracle Health Check巡检脚本使用SOP V2.0:从HTML原始报告→生成Word专业巡检报告→交付客户_2026-06-03
linux·运维·数据库·sql·oracle·报告·巡检
Database_Cool_3 小时前
Hudi 湖仓一体架构:阿里云 AnalyticDB MySQL 原生集成最佳实践
数据库·mysql·阿里云
我是一颗柠檬4 小时前
【Redis】发布订阅与消息队列Day8(2026年)
数据库·redis·后端·缓存
sukioe4 小时前
Redis 持久化+高可用详解:RDB/AOF/混合/主从/哨兵/集群
数据库·redis·缓存