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

相关推荐
阿里小阿希26 分钟前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神31 分钟前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员41 分钟前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java1 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿1 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb
不知名的老吴1 小时前
Redis的延迟瓶颈:TCP栈开销无法避免
数据库·redis·缓存
YOU OU1 小时前
三大范式和E-R图
数据库
一江寒逸1 小时前
零基础从入门到精通MySQL(上篇):筑基篇——吃透核心概念与基础操作,打通SQL入门第一关
数据库·sql·mysql
@土豆1 小时前
Ubuntu 22.04 运行 Filebeat 7.11.2 崩溃问题分析及解决文档
linux·数据库·ubuntu
专注API从业者1 小时前
淘宝商品详情 API 与爬虫技术的边界:合法接入与反爬策略的技术博弈
大数据·数据结构·数据库·爬虫