【Redis】事务

前言:

对比MySQL事务:【MySQL篇】事务的认识以及四大特性-CSDN博客

  • 弱化的原子性: redis 没有 "回滚机制". 只能做到这些操作 "批量执行". 不能做到 "一个失败就恢复到初始状态".
  • 不保证一致性: 不涉及 "约束". 也没有回滚. MySQL 的⼀致性体现的是运行事务前和运行后 , 结果都是合理有效的, 不会出现中间非法状态.
  • 不需要隔离性: 也没有隔离级别, 因为不会并发执行事务 (redis 单线程处理请求) .
  • 不需要持久性: 是保存在内存的. 是否开启持久化, 是redis-server 自己的事情, 和事务无关.

Redis的事务没有像MySQL那么全,它主要的意义将操作"打包"成一个整体,避免其他客户端的命令,插队到中间~

Redis实现事务,是在里面引入了一个队列(每个客户端都有)

当开启事务的时候,客户端输入命令,就会发送到服务器并且命令进入队列中,并不是立即执行,而是遇到执行事务的命令时候,这时会把队列里面的命令按照顺序依次执行~

因此, Redis 的事务的功能相比于 MySQL 来说, 是弱化很多的. 只能保证事务中的这几个操作是 "连续的", 不会被别的客户端 "加塞", 仅此而已.


事务操作:

MULTI:开启事务

此时队列中保存了上述请求,但如果其他客户端想查看里面的内容是查找不到的

EXEC:执行事务

DISCARD:

放弃当前事务. 此时直接清空事务队列. 之前的操作都不会真正执行到.

WATCH:

在执行事务的时候, 如果某个事务中修改的值, 被别的客户端修改了, 此时就容易出现数据不⼀致的问题.

例如以下场景

但如果使用了watch命令

UNWATCH:取消对key监控,是watch的逆操作

相关推荐
Seven9714 分钟前
一文带你了解缓存和数据库一致性问题
redis·mysql
heath ceTide24 分钟前
第二章从事件驱动到信号
数据库·系统架构
StarRocks_labs34 分钟前
欧洲数字化养殖平台 Herdwatch 借力 Iceberg + StarRocks 提升分析能力
数据库·starrocks·iceberg·湖仓一体架构·herdwatch
TDengine (老段)1 小时前
TDengine IDMP 5 个实测场景让监控变简单
大数据·数据库·物联网·ai·时序数据库·tdengine·涛思数据
叫我阿柒啊2 小时前
Java全栈开发面试实战:从基础到复杂场景的深度解析
java·数据库·spring boot·面试·vue·测试·全栈开发
万邦科技Lafite2 小时前
京东API分类接口实战指南:获取各类商品信息
数据库·人工智能·api接口·开放api·电商开放平台
望获linux5 小时前
【Linux基础知识系列】第一百一十篇 - 使用Nmap进行网络安全扫描
java·linux·开发语言·前端·数据库·信息可视化·php
乘乘凉5 小时前
Python中函数的闭包和装饰器
前端·数据库·python
百锦再5 小时前
四、Python 脚本常用模块(续)
jvm·数据库·oracle
༒࿈༙྇洞察༙༙྇྇࿈༒8 小时前
PostgreSQL快速入门
数据库·postgresql