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才能避免这种 "覆盖冲突"

相关推荐
飞翔的小->子>弹->18 小时前
CMK、CEK
服务器·数据库·oracle
peixiuhui18 小时前
Iotgateway技术手册-7. 数据库设计
数据库·iotgateway·开源dotnet·arm工控板·开源网关软件·开源数据采集
麦兜*18 小时前
【Spring Boot】 接口性能优化“十板斧”:从数据库连接到 JVM 调优的全链路提升
java·大数据·数据库·spring boot·后端·spring cloud·性能优化
qq_3344668618 小时前
U9补丁同步的时候报错
数据库
施嘉伟18 小时前
KSQL Developer 测试记录
数据库·kingbase
谱度众合18 小时前
【蛋白互作研究】邻近标记PL-MS实验指南:如何精准获取目标蛋白的基因序列?
数据库·科技·蛋白质组学·药物靶点·生物科研
坐不住的爱码18 小时前
Nacos实例缓存
缓存·cloud
麦聪聊数据18 小时前
生成测试数据(三):从建表到 CRUD 的冷启动
数据库·sql
Awkwardx18 小时前
MySQL数据库—MySQL复合查询
数据库·mysql