Redis事务

谈到事务我们不由的想起MySQL的事务的四个特性:原子性,一致性,持久性,隔离性

但Redis事务与其存在一定区别

弱化的原子性:Redis 会对一系列操作进行打包,要么都执行,要么都不执行,但是相较于MySQL,它不具备某些操作执行失败后的回滚

不具备一致性:Redis没有 约束,也不具有回滚性,事务执行过程中操作很有可能出现问题,导致结果的不一致

不具备持久性:Redis本事是内存数据库,主要存储内存数据,虽然有持久化机制,但持久化机制与持久性并没有直接关系

**不具备隔离性:**Redis 是一个单线程的服务器,所有的请求都是"串行"的

Redis 事务存在的意义呢就是

将多个命令打包后一次性、顺序性、排他性执行。事务的主要作用是确保一组命令在执行过程中不被其他客户端的命令打断,从而实现操作的完整性

Redis事务用于哪些场景呢

事务的指令

开启事务 MULTI

执行事务EXEC

取消事务 DISCARD

watch 是对数据进行监控 看是否数据在事务外部被修改

unwatch就是取消对数据的监控

如上述时间轴 如果我们不进行监控则 最终结果是222 但存在歧义 明明是set key 333后执行 那为什么呢

因为当exec执行时它才会执行set key 222 ,为了解除歧义 我们可以使用watch 去监控事务外对数据的操作,watch key 依旧按照上述操作 最后会提示 nil而不是ok 而且最终结果是333

关于watch的实现 就相当于"乐观锁"

如果判定发现版本号比watch时记录的版本号大 那就说明被其他客户端修改了,就丢弃事务中的修改

如果一致才执行事务中的修改

Redis 事务是 "先排队、后批量执行",没有watch的话,事务里的命令会在exec时 "覆盖" 事务外的操作结果;加了watch才能避免这种 "覆盖冲突"

相关推荐
周杰伦的稻香8 小时前
Go + Redis:本地部署高性能图片主色调提取服务
开发语言·redis·golang
是发财不是旺财8 小时前
Hermes 网关四层权限控制方案:让 AI Agent 安全地查数据库
数据库·安全·agent·openclaw·hermes
阿正的梦工坊8 小时前
【Rust】04-借用、引用与切片
java·数据库·rust
AOwhisky8 小时前
学习自测与解析:MySQL第五、六、七期核心知识点详解
运维·数据库·笔记·学习·mysql·云计算
阿标在干嘛8 小时前
政策平台的推送系统:消息队列、定时任务、AB测试的工程实践
服务器·数据库·ab测试
Upsy-Daisy9 小时前
Hermes Agent 学习笔记 02:安装、配置与第一次运行
java·前端·数据库
大囚长9 小时前
大模型API的上下文缓存(Contextual Cache)
人工智能·缓存
小二·9 小时前
Redis 7 分布式缓存架构实战
redis·分布式·缓存
Tongpao_SSDHDD9 小时前
希捷酷鹰ST6000VX008实测解析:中小安防监控高性价比存储方案
大数据·数据库·人工智能
蓝鸟19749 小时前
Oracle超大DMP备份文件瘦身、日志精简、磁盘空间优化实战方案日志
数据库·oracle·数据库运维·生产运维实战·oracle避坑·磁盘空间优化·oracle日志清理