Redis进阶(二):事务

redis事务特点

弱化的原子性

redis事务的原子性不像MySQL原子性一样,执行不成功的话,redis事务不会进行回滚操作

不具备一致性

redis没有约束,也没有回滚机制,因此事务执行的过程中如果某个修改操作出现失败,就可能引起前后不一样的结果

不具备持久性

redis本身就是内存数据库,数据存储在内存中的。而且持久化机制和事务的持久性没有啥直接关系

不涉及隔离性

redis是单线程的服务器程序,命令都是串行执行的

认识redis事务

redis事务一大重点在于将一些命令打包到一起。开启事务的时候,此时客户端将输入命令发给服务器并且进入一个队列,当遇到"执行事务"命令的时候,此时就会把队列中的这些任务按照顺序依次执行,这是在redis主线程完成的,主线程将事务中的所有任务执行完,再去做别的任务。

事务命令

开启事务 MULTI
执行事务 EXEC
放弃当前事务 DISCARD
监控key WATCH

watch指令可以监控key在multi和exec之间,看看这个key有没有被外部的客户端所修改

watch实现原理

redis的watch基于版本号这样的机制实现了类似乐观锁。

因此watch实际上就是在exec处加上一个判定条件罢了

相关推荐
morris13122 分钟前
【redis】布隆过滤器的Java实现
java·redis·布隆过滤器
椰椰椰耶26 分钟前
【redis】全局命令set、get、keys
数据库·redis·缓存
月落星还在34 分钟前
Redis 内存淘汰策略深度解析
数据库·redis·缓存
五行星辰36 分钟前
Java链接redis
java·开发语言·redis
左灯右行的爱情38 分钟前
Redis- 切片集群
数据库·redis·缓存
LKAI.38 分钟前
MongoDB用户管理和复制组
linux·数据库·mongodb
周小闯1 小时前
Easyliev在线视频分享平台项目总结——SpringBoot、Mybatis、Redis、ElasticSearch、FFmpeg
spring boot·redis·mybatis
PinkandWhite1 小时前
MySQL复习笔记
数据库·笔记·mysql
熬夜苦读学习2 小时前
库制作与原理
linux·数据库·后端
cmgdxrz2 小时前
Mysql中的常用函数
数据库·mysql