当前位置: 首页 > news >正文

Redis学习笔记——第19章 事务

第19章 事务

19.1 事务的实现

19.1.1 事务开始

使用multi命令开启一个事务
通过修改客户端的flags字段为REDIS_MULTI

19.1.2 命令入队

当开启事务之后,exec、discard、watch、multi命令立即执行,而其他命令会放入一个队列中,并返回Queued

19.1.3 事务队列

客户端的mstate保存事务队列,事务保存了参数与执行函数,是一个先进先出的队列

19.1.4 执行事务

遍历事务列表并将结果全部返回给客户端(一次性)

19.2 watch命令的实现(乐观锁)

用以在exec之前监视数据库键,当事务修改了这些键时,事务exec失败

19.2.1 使用watch命令监视数据库键

被监视的键保存为一个字典,值为监视这个键的客户端链表

19.2.2 监视机制的触发

当客户端监视了某个键时,若键被修改,则将监听该键的客户端标识改为REDIS_DIRIY_CAS来使其感知

19.2.3 判断事务是否安全

在执行exec命令时,查看标识是否为REDIS_DIRIY_CAS,若是,则不执行任务

19.2.4 一个完整的watch事务执行过程

在一个客户端加了watch,开启事务之后,若其他客户端修改了watch中操作的键之后,会将watch这些键的客户端标识修改为REDIS_DIRIY_CAS,该客户端再执行exec命令便会被拒绝

19.3 事务的ACID属性

19.3.1 原子性

如果在入队期间发现命令错误,则不会执行,但是如果在执行期间发生异常,则不会回滚整个事务,因此不具有原子性

19.3.2 一致性

redis数据库具有一致性,不会因为特殊情况出现导致redis数据库丢失这种特性

19.3.3 隔离性

redis数据库是单线程数据库,则一定具有隔离性

19.3.4 持久性

只有每次执行事务前使用SAVE命令才可以保证事务具有持久性,但是这种做法效率低下,所以可以认为redis数据库不具有持久性

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 【算法】递归实现二分查找(优化)以及非递归实现二分查找
  • RMAN-06618不同版本之间RMAN无法连接
  • 『C++实战项目 负载均衡式在线OJ』二、编译模块编写(持续更新)
  • 【前端 22】使用Nginx部署前端项目
  • 手持式气象站:科技赋能精准气象观测
  • 长短期记忆网络LSTM
  • 自制安卓车机软件(含APP)
  • 1、爬⾍概述
  • 【2024】Datawhale AI夏令营 Task4笔记——vllm加速方式修改及llm推理参数调整上分
  • 神经网络基础--激活函数
  • 深拷贝——JSON.stringify()序列化和JSON.prase()反序列化
  • 【C语言】Top K问题【建小堆】
  • 浙大版《C语言程序设计(第3版)》题目集
  • JavaScript 继承百花齐放:从原型链到 ES6 类
  • 软设之TCP/IP协议
  • ----------
  • 230. Kth Smallest Element in a BST
  • Android Studio:GIT提交项目到远程仓库
  • Angular2开发踩坑系列-生产环境编译
  • Netty+SpringBoot+FastDFS+Html5实现聊天App(六)
  • Node项目之评分系统(二)- 数据库设计
  • Python 反序列化安全问题(二)
  • scrapy学习之路4(itemloder的使用)
  • ViewService——一种保证客户端与服务端同步的方法
  • Vue全家桶实现一个Web App
  • vue学习系列(二)vue-cli
  • 百度地图API标注+时间轴组件
  • 复杂数据处理
  • 离散点最小(凸)包围边界查找
  • 聊聊springcloud的EurekaClientAutoConfiguration
  • 使用Gradle第一次构建Java程序
  • 思否第一天
  • 微信公众号开发小记——5.python微信红包
  • 我感觉这是史上最牛的防sql注入方法类
  • 云栖大讲堂Java基础入门(三)- 阿里巴巴Java开发手册介绍
  • 不要一棍子打翻所有黑盒模型,其实可以让它们发挥作用 ...
  • !!java web学习笔记(一到五)
  • # Swust 12th acm 邀请赛# [ E ] 01 String [题解]
  • ### RabbitMQ五种工作模式:
  • #android不同版本废弃api,新api。
  • $.type 怎么精确判断对象类型的 --(源码学习2)
  • (02)vite环境变量配置
  • (04)odoo视图操作
  • (06)Hive——正则表达式
  • (1)SpringCloud 整合Python
  • (delphi11最新学习资料) Object Pascal 学习笔记---第5章第5节(delphi中的指针)
  • (delphi11最新学习资料) Object Pascal 学习笔记---第8章第2节(共同的基类)
  • (echarts)echarts使用时重新加载数据之前的数据存留在图上的问题
  • (五)c52学习之旅-静态数码管
  • (转)创业家杂志:UCWEB天使第一步
  • (轉貼) 寄發紅帖基本原則(教育部禮儀司頒布) (雜項)
  • .NET Core SkiaSharp 替代 System.Drawing.Common 的一些用法
  • .net 按比例显示图片的缩略图
  • .NET 使用 JustAssembly 比较两个不同版本程序集的 API 变化
  • .NET 中使用 TaskCompletionSource 作为线程同步互斥或异步操作的事件