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就相当于基于版本号这样的机制来实现的"乐观锁"

总结:

相关推荐
小七-七牛开发者13 小时前
TokenPilot:让 LLM Agent 长会话成本降 60%+ 的上下文管理
缓存·agent·token·context·上下文·推理成本
ClouGence18 小时前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将21 小时前
从零实现数据库(2)——HashIndex + IndexManager
数据库
Nturmoils2 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波2 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
倔强的石头_3 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库
用户3169353811836 天前
Java连接Redis
redis
倔强的石头_6 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
冬奇Lab6 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
ClouGence7 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle