【Redis】缓存中的事务

官方地址,先上为敬

redis.io/docs/manual...

什么是事务

数据库中的事务是指在一次与数据库连接的会话中,所有的SQL语句,要么都成功,要么都失败。在Redis中,事务是指可以一次执行多个命令,本质是一组命令的集合。一个事务中的所有命令都会被序列化,按顺序地串行执行而不会被其他命令插入

Redis的事务有什么作用

可以一次性、顺序性、排他性的执行一系列命令(一个队列中)

Redis事务 🆚 数据库事务

Redis事务的特点

  1. 单独的隔离操作
    1. Redis的事务仅仅是保证事务里的操作会被连续独占的执行,redis命令执行是单线程架构,在执行完事务内所有指令前是不可能再去同时执行其他客户端的请求的
  1. 没有隔离级别的概念
    1. 因为事务提交前任何指令都不会被实际执行,也就不存在"事务内的查询要看到事务里的更新,在事务外查询不能看到"这种问题了
  1. 不保证原子性
    1. Redis的事务不保证原子性,也就是不保证所有指令同时成功或同时失败,只有决定是否开始执行全部指令的能力,没有执行到一半进行回滚的能力
  1. 排它性
    1. Redis会保证一个事务内的命令依次执行,而不会被其它命令插入

事务相关指令

正常执行

  • 事务开始:multi
  • 事务结束:exec

取消事务

  • 事务开始:multi
  • 事务取消:discard

异常情况

  • Redis不支持回滚(rollbacks)
  • 语法错误,全部取消(全体连坐)
  • 语法通过,对的成功,异常的失败(冤头债主)

watch监控

Redis使用的是乐观锁(为了高性能)

乐观锁

Optimistic Lock,每次拿数据都认为别人不会修改,所以不会上锁,但是在更新是我时候会判断下此期间别人有没有去更新过这个数据

乐观锁策略

提交版本必须大于当前记录版本才能执行更新,否则整个事务失败

Redis使用 watch 提供乐观锁,类似CAS(Check and Set)

语法操作

  • watch key 添加监控
  • unwatch key 取消监控 执行exec、或者客户端连接丢失监控会自动取消

实操实例

exec结束当前事务,返回了nil,再次查询name发现并未修改成功,而且a的修改也未成功,即整个事务失败了

x

总结

  • 开启:以MULTI开始一个事务
  • 入队:将多个命令入队到事务中,接到这些命令并不会立即执行,而是放到等待执行的事务队列里面
  • 执行:由EXEC命令触发事务
相关推荐
Armyyyyy丶4 小时前
Redis底层实现原理之五大基础结构
数据结构·redis·缓存
PXM的算法星球8 小时前
ZooKeeper vs Redis:分布式锁的实现与选型指南
redis·分布式·zookeeper
寒士obj9 小时前
Redisson分布式锁:看门狗机制与续期原理
redis·分布式
2302_8097983210 小时前
【Redis】缓存的穿透、击穿和雪崩
数据库·redis·缓存
Badman10 小时前
分布式系统下的数据一致性-Redis分布式锁
redis·分布式·后端
努力努力再努力wz14 小时前
【c++进阶系列】:万字详解AVL树(附源码实现)
java·运维·开发语言·c++·redis
酷ku的森1 天前
Redis中的hash数据类型
数据库·redis·哈希算法
Arva .1 天前
Redis
数据库·redis·缓存
博一波1 天前
Redis 集群:连锁银行的 “多网点智能协作系统”
数据库·redis·缓存
tuokuac1 天前
Redis 的相关文件作用
数据库·redis·缓存